【4】iOS ARC学习笔记——strong、weak区别

<span style="font-family: 宋体; background-color: transparent;">在iOS中我们无法使用垃圾回收机制,因为垃圾回收机制对于移动设备的可用性产生了非常不利的影响,因为移动设备比电脑更加私人化,资源更少。用户不可能接受在玩游戏或者打电话的时候因为系统突然进行内存清理而卡住。</span>

apple公司的解决方案是采用自动引用计数(automatic reference counting)ARC。ARC机制会追踪你的对象并且决定哪一个仍会使用而哪个不会在用到。如果你启用ARC,只管像平时那样按需分配并使用对象,编译器会帮助你自动插入retain和release。重点指出的是ARC是在编译的时候进行工作,而垃圾回收器则是在运行时工作。

ARC开发过成中会运用到strong,weak,copy,unsafe_unretained等关键字.他们可以与以前的关键字对应学习strong与retain类似,weak与unsafe_unretained功能差不多(有点区别,等下会介绍,这两个新 关键字与assign类似)。

strong关键字与retain相似,用了它,引用计数自动+1,用实例更能说明一切

@property (nonatomic, strong) NSString *string1;   
    @property (nonatomic, strong) NSString *string2;
       有这样两个属性

 
 
  1. @synthesize string1;   
  2. @synthesize string2; 

猜一下下面代码将输出什么结果?

 
 
  1. self.string1 = @"String 1";   
  2. [self.string2 = self.string1;   
  3. [self.string1 = nil;  
  4. [NSLog(@"String 2 = %@", self.string2); 

结果是:String 2 = String 1

由于string2是strong定义的属性,所以引用计数+1,使得它们所指向的值都是@"String 1", 如果你对retain熟悉的话,这理解并不难。

接着我们来看weak关键字:

如果这样声明两个属性:

 
 
  1. @property (nonatomic, strong) NSString *string1;   
  2. @property (nonatomic, weak) NSString *string2; 

并定义

 
 
  1. @synthesize string1;   
  2. @synthesize string2; 

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

 
 
  1.     self.string1 = [[NSString alloc] initWithUTF8String:"string 1"];   
  2. elf.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关键字帮我们做了这一步。

接着我们来看unsafe_unretained

从名字可以看出,unretained且unsafe,由于是unretained所以与weak有点类似,但是它是unsafe的,什么是unsafe的呢,下面看实例。

如果这样声明两个属性:

并定义

 
 
  1. @property (nonatomic, strong) NSString *string1;   
  2. @property (nonatomic, unsafe_unretained) NSString *string2; 

再来猜一下,下面的代码会有什么结果?

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

请注意,在此我并没有叫你猜会有什么输出,因为根本不会有输出,你的程序会crash掉。 原因是什么,其实 就是野指针造成的,所以野指针是可怕的。为何会造成野指针呢?同于用unsafe_unretained声明的指针,由于 self.string1=nil已将内存释放掉了,但是string2并不知道已被释放了,所以是野指针。然后访问野指针的内存就造成crash.  所以尽量少用unsafe_unretained关键字。


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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值