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<self.requestArray.count; i++) {
NSURLSessionTask *sub = self.requestArray[i];
[sub cancel];
[self.requestArray removeObject:sub];
}
}
那是因为我在父类中的 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 工程中出错
这里说下两种错误的操作:
(1)直接把多层级的文件拖到工程中
(2)add file 到工程中时选择的文件夹不在工程中(比如在桌面)
【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的时候可以使用,打包发布的时候注意取消这个模式。
最后发现 baseItem[i] 在事先声明中不多,比 viewClassArray 的个数少了很多,最后造成了这个内存错误。
8. &&的条件语句判断中出错
if (baseItem[i].isMust&&(NilStr([baseItem[i] itemText]) ||[baseItem[i].itemText isEqualToString:@"-请选择-"])) {
return YES;
}
这个条件判断中有时候会出现前面成立后面不成立,但是整个判断是成立的错误状态,这个出错是偶然的,不知道什么原因,反正 && 两边都用 ()包裹住,这样更不容易出错。
9.一个UITbaleViewCell中下拉框的初始化失败的Bug
场景:下拉框是在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 有关的网路请求
【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 即为可以使用的数组数据了。