iOS开发Xcode崩溃在main函数入口时如何定位Bug的一个小方法以及一个恶心的bug介绍

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];

©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,560评论 4 361
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,104评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,297评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,869评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,275评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,563评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,833评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,543评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,245评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,512评论 2 244
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,011评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,359评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,006评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,062评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,825评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,590评论 2 273
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,501评论 2 268

推荐阅读更多精彩内容