扒虫篇- Bug日志 Ⅸ

扒虫篇- Bug日志 Ⅸ_第1张图片

1、UITabBarItem里设置的文字不显示

PersonViewController *vc3=[[PersonViewController alloc] init];
 vc3.tabBarItem.title=@"我的";
 vc3.tabBarItem.image=[[UIImage imageNamed:@"tabBar2n"] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
 vc3.tabBarItem.selectedImage=[[UIImage imageNamed:@"tabBar2l"] imageWithRenderingMode:UIImageRenderingModeAlwaysOriginal];
 UINavigationController *nav3=[[UINavigationController alloc] initWithRootViewController:vc3];

这样设置不显示。

 IndexViewController *vc1=[[IndexViewController alloc] init];
 UINavigationController *nav1=[[UINavigationController alloc] initWithRootViewController:vc1];
 UITabBarItem *tabBar = [[UITabBarItem alloc]initWithTitle:@"首页" image:[UIImage imageNamed:@"tabBar0n"] selectedImage:[UIImage imageNamed:@"tabBar0l"]];
 nav1.tabBarItem = tabBar;

这样设置就可以显示了。

2、解决Collection <__NSArrayM: 0xb550c30> was mutated while being enumerated.-

  ViewTest[2638:c07] *** Terminating app due to uncaught exception 'NSGenericException', reason: '
  Collection <__NSArrayM: 0xb550c30> was mutated while being enumerated.'

当程序出现这个提示的时候,是因为你一边便利数组,又同时修改这个数组里面的内容,导致崩溃,最后发现确实是这样的原因,不过问题是,很多时候这样的写法并不会造成崩溃,可见这样的Bug是偶现的。

for (NSURLSessionTask *sub in self.requestArray) {
     [sub cancel];
    [self.requestArray removeObject:sub];
}

把for- in 循环修改为 for 循环即可。

3.正常的网路请求突然出错

- (void)cancelAllRunningRequest
  {
   for (int i = 0; i

那是因为我在父类中的 viewWillDisappear 中调用了上述方法,
忽略了 VC的生命周期造成的问题,
因为在 V2的 ViewDidLoad中发起的网路请求会在 V1 的viewWillDisappear中被取消,所以就会出现上面的Bug。

正确的方法是在 父类中的viewDidDisappear 调用上述的方法即可。

4.Auto property synthesis will not synthesize property 'title'; it will be implemented by its superclass, use @dynamic to acknowledge intention 警告!

这个问题是因为,父类和子类有一个相同名称的属性。
编译器自动给属性delegate合成getter和setter的时候将会在它的父类上实现,也就是说其父类也有一个delegate属性,现在它不知道到底是哪一个delegate.

所以遇到这个问题怎么解决?在子类中显式的声明一个@synthesize name = _name;就好,这样子类就会如愿的产生他的壳,编译器也不纠结了。

5.一个匪夷所思的Bug

两个工程中同样的代码,一个可以执行Post请求,一个不可以,我一直以为是 网路请求设置出了问题,因为一直报的是网路请求错误,貌似跟服务器无关。

 URL :/baseinfos/dealResultForAppWarnCheckedBillDetail.gx?   
 data={"sysuserid":"10000950","fopinion":"Okkkk","fresult":"2","fwarnType":"IvFoodSalemas","fid":"43767","fwarnId":"303381"}
 (lldb) po dic
 {
 msg = "\U5904\U7406\U6210\U529f";
 status = 1;
 }
 
 URL :/baseinfos/dealResultForAppWarnCheckedBillDetail.gx?   
参数:{"sysuserid":"20180111134320122911","fopinion":"ok","fresult":"2","fwarnType":"IvFoodSalemas","fid":"43767","fwarnId":"303381"}

纠结了很久,最后实在没办法了,就打印了两个请求中的参数,发现只有 sysuserid 这个参数不一样,貌似还是长度不一样造成的,难道因为参数的原因可以造成这样的网络请求错误??最后试了一下,还真是参数的问题,把参数换成短的那个,就请求成功了,涨姿势了。

6.多层级文件夹拖进Xcode 工程中出错

扒虫篇- Bug日志 Ⅸ_第2张图片

这里说下两种错误的操作:
(1)直接把多层级的文件拖到工程中
(2)add file 到工程中时选择的文件夹不在工程中(比如在桌面)

扒虫篇- Bug日志 Ⅸ_第3张图片

【1】这里上面两个操作的最终效果都是只是引用了文件夹中的文件,当文件所在处的文件被删除时,新工程中的对应文件就会变成红色,
【2】或者在新工程中修改文件,修改的相当于原工程中的文件,原工程中的文件自然会被修改了。

正确的操作是:先把需要添加的文件夹拷贝并移动到新工程文件夹中,然后右键 add file 到工程即可实现多层级文件夹的添加,而且不会出错。

7.Thread 1: EXC_BAD_ACCESS (code=EXC_I386_GPFLT)

 Class class = NSClassFromString(viewClassArray[i]);
 baseItem[i] = [[class alloc]init];
 [baseItem[i] setItemTitle:titleA[i]];
 [self addSubview:baseItem[i]];

EXC_BAD_ACCESS 这个错误,可以这么说,90%的错误来源在于对一个已经释放的对象进行release操作(code=1,是已经释放的对象又进行释放;code=2,是对已经释放完的,即计数为零的对象又进行使用——个人理解)。


开启僵尸模式,这个模式比较耗性能,一般Degub的时候可以使用,打包发布的时候注意取消这个模式。
扒虫篇- Bug日志 Ⅸ_第4张图片


最后发现 baseItem[i] 在事先声明中不多,比 viewClassArray 的个数少了很多,最后造成了这个内存错误。

8. &&的条件语句判断中出错

if (baseItem[i].isMust&&(NilStr([baseItem[i] itemText]) ||[baseItem[i].itemText isEqualToString:@"-请选择-"])) {
                return YES;
            }

这个条件判断中有时候会出现前面成立后面不成立,但是整个判断是成立的错误状态,这个出错是偶然的,不知道什么原因,反正 && 两边都用 ()包裹住,这样更不容易出错。

9.一个UITbaleViewCell中下拉框的初始化失败的Bug

扒虫篇- Bug日志 Ⅸ_第5张图片
修复过后的理想效果

场景:下拉框是在cell中初始化的,下拉框的初始化方法在 VC中,而且下拉框的初始化事件是利用 UIResponder 传递的。

问题:第一个cell初始化的时候,里面的下拉框的初始化失败,因为VC中的对应的初始化事件并没有被调用,后续添加cell时,cell中的下拉框还是初始化失败,但是滚动UITbaleView 、或者 reLoad UITbaleView时却可以正常的触发,猜想是UITbaleView 初始化时,或者insertRowsAtIndexPaths 添加的cell在 cellForRowAtIndexPath 后才加载在UITbaleView上,所以在cellForRowAtIndexPath 的 setModel初始化时UIResponder是找不到其父视图的。

解决办法:把VC中的下拉框初始化方法移到 Cell中,这样就不会出现上述的问题了。而且移到cell中后详情和新增页面中都不用管理下拉框初始化方法了,更合理。

10.一个 OS_dispatch_data 有关的网路请求

扒虫篇- Bug日志 Ⅸ_第6张图片

扒虫篇- Bug日志 Ⅸ_第7张图片

【1】首先这个网络请求(http://XXXXXXXX:80XX/WebServiceServlet?method=getAllResourceDetailByOrg&orgCode=7654)只支持GET请求,POST请求没有数据返回也是奇葩。
【2】OS_dispatch_data 不能用 JSON直接解析,是无法直接使用的。
【3】需要把 OS_dispatch_data 转为 字符串,字符串去掉首尾非JSON的字符后,剩余的部分就可以使用 JSONKit 进行解析了。

 //OS_dispatch_data
     NSString *str = [[NSString alloc]initWithData:data encoding:NSUTF8StringEncoding];
     if (str.length<6)return ;
     NSString *str1 = [str substringWithRange:NSMakeRange(5, str.length-6)];
     NSArray *ss = [str1  objectFromJSONString];
     ss 即为可以使用的数组数据了。

你可能感兴趣的:(扒虫篇- Bug日志 Ⅸ)