// ——————更新内容————————-
NSArray *arr;Nsstring *str;NSMutableArray *mutableArr;// in the dealloc// it should have to following[arr release];[str release];[mutableArr release];
该功能将被调用3次?
解决方法 当一个对象的保留计数达到零时,就调用dealloc方法.每次保留呼叫的保留计数增加1,每次释放呼叫减少一次.自动释放在当前NSautoreleasePool耗尽时(通常在事件周期结束时)安排将来的释放调用,但您可以在内存密集型 *** 作上设置自己的NSautoreleasePools. (有关详细信息,请参阅NSautoreleasePool文档.)什么应该放入dealloc?您应该为该类的对象保留的每个成员对象放置一个版本.
一些事情使这更容易. nil对象将静静地忽略发送给它的任何消息,因此当foo = nil时[foo release]不是BUG.但是,两次释放对象可能会导致严重问题.我的(几乎不是唯一的)解决方案就是在我发布它时明确地将我刚发布的内容设置为nil.事实上,我将nil赋值放在与发布相同的行上,这样我就可以找到“发布”并找到我错过的地方.例:
@interface MyClass { Foo *foo; bar *bar; NSInteger baz;}-(voID)dealloc;@end@implementation MyClass-(voID)dealloc { [foo release]; foo = nil; [bar release]; bar = nil; [super dealloc];}@end
即使该变量即将超出范围或对象即将消失,我也会将nil分配给变量.为什么?如果同一个类的另一个对象在我发布之后分配在同一个内存空间中,它可以保证新对象可能不会意外使用并使调试变成一场噩梦. (另请参阅NSZombIEEnabled以获取调试帮助.)
总结以上是内存溢出为你收集整理的objective-c – 目标C中的dealloc是什么全部内容,希望文章能够帮你解决objective-c – 目标C中的dealloc是什么所遇到的程序开发问题。
如果觉得内存溢出网站内容还不错,欢迎将内存溢出网站推荐给程序员好友。
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)