博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
iOS开发 ARC下dealloc的使用
阅读量:6806 次
发布时间:2019-06-26

本文共 1008 字,大约阅读时间需要 3 分钟。

在MRC时代,我们需要在 dealloc中做很多,比如释放对象,等等;

如今我们已经进入ARC时代,对于普通对象的释放,系统已经帮我们做好了;

那是否可以高枕无忧了呢?在ARC下我们应该做什么?


观点:

ARC下,系统可以帮我们释放该对象,及其包含的对象;

但是却无法释放不属于该对象的一些东西,如:


1.通知的观察者,或KVO的观察者


由于通知中心是系统的一个单例,你在注册通知的观察者时,实际上是在通知中心注册的,

这时,即使ARC下系统帮我们释放了对象,但是在通知中心的观察还是没有移除,那么当有

该通知时,依然会尝试调用该对象的接受通知的方法,这可能会导致一些问题.

这一点有点像,你晚上六点下班了...但是却没有刷卡...,


2.对象强委托/引用的解除(例如XMPPMannerger的delegateQueue)


对于其他的对象来把你当做委托 delegate时,并且是 强引用时,即时你自身被释放,但是引用你的对象依然还在,

这时需要在引用你的对象移除该delegate


3.做一些其他的注销之类的操作(关闭程序运行期间没有关闭的资源)


一个对象,如一个ViewController在销毁之前有可能需要和server打交道;

这时我们也可以在dealloc中写


关于dealloc的底层实现,可以参照objc运行时代码


示例,ARC下我们应该做的:

[html]  

  

  1. - (void)dealloc  

  2. {  

  3.     [[NSNotificationCenter defaultCenter] removeObserver:self];//移除通知观察者  

  4.     [[XMPPManager sharedManager] removeFromDelegateQueue:self];//移除委托引用  

  5.   [ [MyClass shareInstance]  doSomething ]//其他操作  

  6.      

  7. }  



ARC下我们没必要做的



[html]  

  

  1. - (void)dealloc  

  2. {  

  3.     _name = nil;  

  4.    [_time invalid];  

  5. }  




[html]  

  

  1. 总结: dealloc在ARC下的作用就是释放 系统无法释放的该对象占用的资源,或者其他对象对该对象的引用.  


原文出自:

本文转自ljianbing51CTO博客,原文链接:http://blog.51cto.com/ljianbing/1871811 ,如需转载请自行联系原作者

你可能感兴趣的文章
厉害了word华为,“万元机”背后是中国品牌的胜利
查看>>
nfs 挂载
查看>>
因为机遇,不会轻易悲伤
查看>>
我眼中的2011年互联网大事记
查看>>
浪潮存储进逼国际一线厂商
查看>>
整理发布一些关于VMware vSphere的文档
查看>>
TCP/IP协议栈中,为什么选择IP层负责分片?
查看>>
使用Sphinx对MySQL数据库进行全文检索
查看>>
基于WinSvr2012共享文件夹的Hyper-V实时迁移之二文件服务器及迁移用虚拟机的创建...
查看>>
linux运行级别0-6的各自含义(考试题答案系列)
查看>>
buffer 与cache 的区别
查看>>
Exchange邮箱数据库事务日志引起磁盘暴涨
查看>>
通过帮网友解答问题训练同学们使用awk,sed案例
查看>>
统计客户端连接数
查看>>
OSSIM中主动与被动探测工具(arpwatch+p0f+pads)组合应用
查看>>
腾讯微博等7家网站实行实名制
查看>>
分布式日志收集系统实践(视频教程)
查看>>
业界大佬患互联网手机焦虑症 圈地运动骤然爆发
查看>>
拍拍二手重装上阵,京东剑指闲鱼胜算几何?
查看>>
看看其实挺心酸的。
查看>>