认识retain copy assign strong weak 的区别

retain: 引用计数+1 目的:不让这个对象释放掉——》MRC-》ARC  strong  weak 
copy : 拷贝 为了原数据更改 影响使用之后的数据 -> 使用copy(拷贝的内容 必须遵守拷贝协议)数组 字典 字符串
assign:直接赋值 用于基本数据类型 -> 也包含演化出来的类型 int NSInteger BOOL float。。。
strong:强引用->不会被轻易释放掉->当对象使用完毕之后 对象释放掉强引用的对象才会被释放掉-》ARC UI控件 自己创建类声明的对象
weak:弱引用->当出现内存警告的时候 告诉编译器 可以释放掉这个对象  UI控件 声明的对象

数字的 使用assgin
数组 字典 字符串 使用copy
其他  使用strong  weak

另外,我在网上还查到一些其他;
凡是nsstring,就用copy,定义一个模型对象,就用strong,只是赋值的,例如int、double、char 以及CGRect类似的就用assign。
当用copy时,set方法会先release旧值,再copy一个新的对象,reference count 为1(减少了对上下文的依赖);当用assign,直接赋值,无retain操作。当用retain,release旧值,retain新值;


而strong与weak的区别
strong类似于retain,会将对象的引用计数器+1,分配内存地址。
weak类似于指针,只是单纯的指向某个地址,但是本身并未分配内存地址。当指向的地址被销毁时,该指针会自动nil。
例子:
  1.    @synthesize string1;   
  2.    @synthesize string2;  

再来猜一下,下面输出是什么? 



    1.    self.string1 = [[NSString alloc] initWithUTF8String:"string 1"];   
    2.    self.string2 = self.string1;   
    3.    self.string1 = nil;  
    4.    NSLog(@"String 2 = %@", self.string2);  


结果是:String 2 = null

分析一下,由于self.string1与self.string2指向同一地址,且string2没有retain内存地址,而 self.string1=nil释放了内存,所以string1为nil。声明为weak的指针,指针指向的地址一旦被释放,这些指针都将被赋值为 nil。这样的好处能有效的防止野指针。在c/c++开发过程中,指针的空间释放了后,都要将指针赋为NULL. 在这儿用weak关键字做了这一步。

   总之,这些需要区分开,对于属性构造方法有很大帮助,可以省去许多麻烦。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值