关于生命周期函数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];

}

 
 
posted @ 2016-02-16 11:24  wangbaixue  阅读(334)  评论(0编辑  收藏  举报