由pushViewController说起可能出线的各种死法

由pushViewController说起可能出线的各种死法,第1张

概述做苹果开发或者果粉对导航条这个东西应该都不陌生,这咚咚在小小的屏幕上通过一个简单的View的队列管理来做到手机界面的有条理管理,但是开发过程程序员可能碰到各种死法,下面分享一二。           例子: MyViewController *sampleViewController = [[[ MyViewController  alloc ] initWithXXX ] autorelease 做苹果开发或者果粉对导航条这个东西应该都不陌生,这咚咚在小小的屏幕上通过一个简单的VIEw的队列管理来做到手机界面的有条理管理,但是开发过程程序员可能碰到各种死法,下面分享一二。           例子: MyVIEwController *sampleVIEwController = [[[ MyVIEwController  alloc ] initWithXXX ] autorelease ];        

[self.navigationController pushVIEwController: sampleVIEwController animated:true];

[sampleVIEwController release];


上面代码通常在一个UITabVIEwController中,某一行选中后,切换到详细内容,上面代码比较简单,先从他的死法说起。

死法1:  objectc程序员菜鸟常放的毛病导致,上面代码必死,为神马呢?

nav的push会导致引用计数的增加,界面会苟延残喘一会,当popvIEw的时候,最后一行release会把sampleVIEwController清0,接着就是autopool回收的的时候XXX了

     终结:为了避免内存泄露,alloc必对应release或者autorelease,但是必须11对应,同理

用全局函数生成的类,你就不要release了,除非你retain(如果你要长期使用,retain是必须的),objectc的内存管理必须小心翼翼,否则。。。,我个人习惯,宁可挂掉也不能泄露,因为挂掉容易发现问题,泄露了又有几个程序员用工具分析解决呢。


开胃菜结束,开始正题:

MyVIEwController  *sampleVIEwController = [[[ MyVIEwController  alloc ] @H_502_193@initWithXXX autorelease ];        

[self.navigationController pushVIEwController: sampleVIEwController animated:true];

死法2:界面无反应,或者把自己界面刷了一下。

      分析可能出线的原因:

1:self.navigationController为nil,空指针执行pushVIEwController直接跳过,接着sampleVIEwController会释放掉,所以界面会无反应。

   self.navigationController为神马会空呢?navigationController是UIVIEwController父类继承来的属性,不是随便都能用的,除非你当前vIEwController是被nav push进来的,或者用xib/代码做成navigationcontroller的root了,cocoa的代码应该是给赋值了。(题外话,我很多界面就是局部用了某个VIEwController,这种情况该vIEwController的nav为空,如果要正确使用,可以从app取,可以自己赋值,可以整体界面取。。。想咋取都行)

2、self.navigationController为nil,界面挂了

   如果你sampleVIEwController用到了网络异步请求,在initWithXXX的时候会去取数,那么你10有89会挂掉。

   原因分析:大家网络请求,经常如下:

TwitterClIEnt   *twitterClIEnt = [[TwitterClIEnt alloc] initWithTarget:self action:@selector(XXXReceive:obj:)];

 

[twitterClIEnt getXXX:param];

恭喜你,这种情况不管是不是navigationController为空,你程序极容易挂掉,原因就是因为网络请求我们都会用异步方式来拉取数据,当数据回来之后,会回调到本类的XXXReceive:obj方法,

但是如果界面退出了,数据才收到将如何?那就是不是空指针调用了,TwitterClIEnt里纪录的需要回调的内存地址上神马情况都有可能是,回调。。杯具了


解决办法:twitterClIEnt做成成员,在析构的时候该咋收拾twitterClIEnt的就咋收拾一下吧

3、self.navigationController为nil,界面挂了

     和上文一样twitterClIEnt成员了,dealloc也清理了现场,还是会挂

原因分析:异步的问题,twitterClIEnt已经取到数据,但是sampleVIEwController已经被释放了,but dealloc根本没来得及进来。。。

    解决办法,1:确保nav正确,2:尽量在界面vIEwDIDLoad的时候网络请求数据,在dispear的时候清理网络。

总结

以上是内存溢出为你收集整理的由pushViewController说起可能出线的各种死法全部内容,希望文章能够帮你解决由pushViewController说起可能出线的各种死法所遇到的程序开发问题。

如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/web/1064897.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-26
下一篇 2022-05-26

发表评论

登录后才能评论

评论列表(0条)

保存