Objective-c的内存管理问题(copy和retain)

  copy: 建立一个索引计数为1的对象,然后释放旧对象 
retain:释放旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为1 

Copy其实是建立了一个相同的对象,而retain不是: 
比如一个NSString对象,地址为0×1111,内容为@”STR” 
Copy到另外一个NSString之后,地址为0×2222,内容相同,新的对象retain为1,旧有对象没有变化 
retain到另外一个NSString之后,地址相同(建立一个指针,指针拷贝),内容当然相同,这个对象的retain值+1 
也就是说,retain是指针拷贝,copy是内容拷贝。

将一个news设置为这样的属性:
@property (nonatomic, copy) NSString *news;

实现类中:
- (NSString *)news {
return newsTitleLable.text;
}
- (void)setNews:(NSString *)v {
newsTitleLable.text = v;
}

在这里实际上newsTitleLabel.text和news指向的是同一个家伙,
使用copy,是的set的形参v是将其所做的copy给news,这样在释放时就不必考虑会有指向同一个地址空间的问题,可以放心释放release了

你可能感兴趣的:(Objective-c的内存管理问题(copy和retain))