关于生命周期函数dealloc的使用小结

最近在内存销毁上遇到了麻烦,总结下,记住这次血的教训:

1.对象如果不存在了,请将指针置空,养成良好的内存控制习惯。

2.[super dealloc];要在dealloc函数的最后调用(类似于C++的析构函数),这样就可以在自身被销毁之前再次调用自身的函数。

3.对于某些已经使用(alloc,copy和retain)分配内存的对象,可以直接release,对于可能出现分配内存的对象需要做一次判断再去release(比如点击事件响应的)。

4.不用去依靠retainCount输出来判断内存计数器,apple官方文档都申明过可能有误显示

5.在调试模式下可能没有的内存问题会在运行模式下出现,这个时候就要根据经验来判断了,比如首先应该想到的就是dealloc函数中是否写的有问题,或者要考虑这个对象中是否有autorelease的对象被放在dealloc中了,引起了内存的混乱(事实证明有这种情况)

6.最关键的一条:dealloc函数可能在你调试的时候根本没有被调用,原因可能会是对self.XX对象的赋值造成了retainCount+1,这样就会出现对象release的时候没有调用dealloc,所以在进行了(alloc,copy和retain)之后要及时的release,并且自己一定要清除哪个是最后的release,会调用dealloc

 

以下举个例子:

- (void)dealloc {

    [self closeConnection];    //-------------------我可以在这里调用类似关闭连接的操作
    [Table release];              //-------------------像这种已经被分配内存的对象就可以直接销毁
    [SearchBar release];
   
    [keyString release];
    [requestArray release];
    [categoryArray release];
    [flagArray release];
   

    if (categoryViewControl!=nil) {   //-------------------这种对象的存在有可能性的需要做一次空值判断
        [categoryViewControl release];
    }
   
    [super dealloc];

}

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 6
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 6
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值