美文网首页
iOS开发Xcode崩溃在main函数入口时如何定位Bug的一个

iOS开发Xcode崩溃在main函数入口时如何定位Bug的一个

作者: 々莫等闲々 | 来源:发表于2018-04-28 17:57 被阅读0次

    iOS开发中的崩溃有两种,一种是正常崩溃在代码段,能指出来崩溃在哪一句代码,而且会给出crash reason,

    这个一般来讲随便找找就能解决问题了第二种 就是致命到没朋友的崩溃在Main入口函数

    如下图所示,根本在控制台没有任何打印信息,只是停在了main入口

    如何通过Xcode来找到崩溃在Main入口函数的原因??

    首先你要明白,很多这种情况是已经释放的对象再调用其方法就会产生EXC_BAD_ACCESS这样的报错

    Xcode自带Zombie检测的开关

    第一:点这里,选择edit scheme

    第二:勾上zombie对象开关

    这个时候,你把刚才崩溃的程序再来一遍,令人发指的打印出现了

    控制台输出

    2016-11-10 16:59:17.272 XXXXX[14999:433907] *** -[XXXXXXXX respondsToSelector:]:

    message sent to deallocated instance 0x7fa37d8a0c00

    这太强了有没有,瞬间定位到了哪个对象成为了僵尸对象,而你还在对他进行访问,死也死不瞑目,然后你就炸了!

    以后遇到蹦在main函数的坏访问,多半是这种情况导致的,直接开启僵尸检测,就能定位到原因的所在

    下面对我这个恶心的bug做下留念,浪费我那么久去找他

    分析下过程:

    1.有两个页面,A push到 B页面 正常情况下不会有问题,pop回来也正常

    2.但是我在B上面加了个View,view里面是个searchBar

    [self.navigationController.navigationBar addSubview:self.searBackView];

    3.这里需要注意的是我用addSubView的方式加的(如果我加到系统的left or rightItem上去,pop回去的时候会自动回收)

    这就埋下了隐患,我pop回去的时候在dealloc没有做任何处理

    4.这就导致了B页面的顶部View还活着!!!(因为导航栏是共享的),但是B页面已经dealloc了

    dealloc --> SortCategoryProductsViewController

    5.当我A页面的searchBar动画下来的时候或者再次Push的时候,会去调用顶部View的拥有者也就是B页面,但是B

    已经挂了,这个时候直接炸了

    6.你以为结束了么,我擦,这在iOS 9 以上版本根本没事好么,9以下就炸了,血淋淋的教训啊,以后一定在低适配的

    模拟器上多跑跑。这种版本花式炸最烦了

    7.这个故事告诉我们,addsubView的方式加到导航栏上东西,最好在页面死的时候移除

    dealloc能做的事情不多,也就是清理干净一些不必要的麻烦,一定要注意

    [objc] view plain copy

    - (void)dealloc  

    {  

    [self.searBackView removeFromSuperview];  

    self.searBackView = nil;  

    DDLogVerbose(@"dealloc --> %s",object_getClassName(self));  

    }  

    iOS不同版本有不同的兼容BUG,还要注意一点的事,在searchBar初始化的时候最好加上

    [self.searchController.searchBar sizeToFit];

    相关文章

      网友评论

          本文标题:iOS开发Xcode崩溃在main函数入口时如何定位Bug的一个

          本文链接:https://www.haomeiwen.com/subject/ayfnlftx.html