记一次特别的bug

问题现象

push入某个特定的画页,然后再pop出来,然后再切换不同的tabbaritem就会崩溃,而且没有任何提示,也没法定位崩溃位置,哪怕用了$arg1.

猜测,这种情况坏访问的可能性比较大,至少本来在实际 开发中还没有出过这种情况,一般都会记得比如block、notificationcenter 、代理之类的处理。

操作

开启僵尸对象跟踪

好的,现在已经能定位到画页的方法了。

responseForSelector:

于是,打了个方法断点。奇怪,没有定到位。后面,想了想这个方法,很明显是用于代理调用时,判断代理是否响应这个方法的,至于为什么崩溃,就是因为这个代理已经销毁了,这个时间又去判断这个代理是否响应这个方法,故然出理坏访问了。

解决办法

查找页面内的.delegate = self;类似的代码。

定位到UINavigationController的一个代理。朋友为这什么要用这个代理呢,想实现,这个页面隐藏导航栏,而其他页面不隐藏导航栏。

我给出的解决方案

[self.navigationControoler setNavibarHidden:YES animated:YES];

当然离开这个画页时得

[self.navigationControoler setNavibarHidden:NO animated:YES];

另外的解决方法

在当前页面销毁时,记得把UINavigationController的代理置空

其实一般我们开发时,正确的做法就是,在画页消失或者销毁时就应该把dataSource及delegate还有相关对象全部置空,当然很多时候dataSource及delegate不用置空也没什么事。

举个最长见的例子

就是我们开发时一个控制器里有个tableView,然后当然也得设置其dataSource和delegate为self.这种情况下不用置空。那时因为控制器销毁时,这个tableView了销毁了,所以不存在还通过代理来调用当前控制器。

而朋友那个画页就不一样了,因为委托者为UINavigationController,这种情况就比较特别了,当当前画页销毁时,这个委托者是不会销毁的,所以就算画页销毁了也会被调用代理。

小记

原文地址:https://www.cnblogs.com/songxing10000/p/6100261.html