我曾经这样做,直到我发现我的一个保留属性的保留计数在 dealloc 函数之前为零。 (这种情况正常还是不正常?)
注意:这是 RC 条件,而不是 ARC。
比如我下面有4个retained properties,是不是应该一直在dealloc函数中释放?
如果不是,我怎么知道什么时候发布,什么时候不发布?人工判断retainCount?
@property (nonatomic, retain) NSString *fileName;
@property (nonatomic, retain) UIImage *fullSizeImage;
@property (nonatomic, retain) UIImage *thumbnailImage;
@property (nonatomic, retain) UIImageView *checkedImageView;
- (void)dealloc {
[checkedImageView release];
checkedImageView = nil;
[fileName release];
fileName = nil;
[fullSizeImage release];
fullSizeImage = nil;
[thumbnailImage release];
thumbnailImage = nil;
[super dealloc];
}
最佳答案
好吧,如果问题是“总是?”,那么 Wain 几乎是正确的...
简短的回答是肯定的...
因为一般来说,当有人设置一个属性时,就意味着他要把它当作一个属性来使用,也就是他使用它的setter方法来初始化它。
但是(长答案):不,不总是:
如果您在代码中的某处初始化与属性相关联的私有(private)变量,而不使用它的 setter 方法怎么办?请记住,属性不是 var,而只是一种从 Xcode 获取方法以获取和设置与其关联的 var 的有用方法。
换句话说,当你在 .h 中写入时:
@property (nonatomic, retain) NSString *fileName;
在 .m 中:
@synthesize fileName;
你正在声明一个名为 fileName 的 var,并要求 xcode 为你创建 2 个(不可见的)方法:
一个setter,用于在fileName中设置一个新的保留值:
-(void)setFileName:(NSString *)newString{
if (fileName == newString) {
return;
}
NSString *oldString = fileName;
fileName = [newString retain];
[oldString release];
}
还有一个getter,用于获取fileName的值:
-(NSString)fileName{
return fileName
}
因此,当您在代码中的某处使用时:
self.fileName = @"ciao";
你正在使用属性设置方法,就像你直接调用它一样(你可以这样做,不可见的方法 setFileName: 确实存在):
[self setFileName:@"ciao"];
这样做,正如您在 setter 方法中看到的那样,从现在开始 fileName 被保留,因此您应该在 dealloc 中释放它。
但是,回答你的问题:
如果您使用点规则在您的 var 中设置一个新字符串,好的,一切都很好, 但你可能决定在某个地方以标准方式设置它,也许只是为了错误:
fileName = @"ciao";
// code
fileName = @"Hallo";
// code
fileName = @"Bye";
这样你就没有使用属性setter方法,而是直接使用var,所以fileName不会被保留,如果你试图释放它,那么你可能会崩溃......
附言: 人工判断retainCount?
不,永远不要那样做
关于ios - 保留的属性应该总是在 dealloc 函数中释放,对吗?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/16708261/