1. strong,retain,copy
strong weak是ARC引入的,strong相当于retain,但是对于有的类型,例如NSString,则使用strong相当于使用copy
这样直接用strong就可以直接处理retain和strong的情况了。 weak相当于assign,但是比后者多一点:对象被干掉时会将weak引用设为nil,而对nil发送消息都不会导致崩溃 否则weak引用为野指针,会出现问题上面说strong 有copy的功能是错误的哦。实验例子
- (void)test{ NSMutableString *newStr = [NSMutableString stringWithFormat:@"abcd"]; self.retainStr = newStr; self.strongStr = newStr; self.copStr = newStr; NSLog(@"newStr sting:%@", newStr); NSLog(@"retain sting:%@", self.retainStr); NSLog(@"strong string:%@", self.strongStr); NSLog(@"copy string:%@", self.copStr); NSLog(@"------------"); [newStr appendString:@"123"];// [newStr appendString:@"-456"]; NSLog(@"newStr sting:%@", newStr); NSLog(@"retain sting:%@", self.retainStr); NSLog(@"strong string:%@", self.strongStr); NSLog(@"copy string:%@", self.copStr); NSLog(@"------------"); newStr = nil; NSLog(@"newStr sting:%@", newStr); NSLog(@"retain sting:%@", self.retainStr); NSLog(@"strong string:%@", self.strongStr); NSLog(@"copy string:%@", self.copStr); NSLog(@"------------"); [newStr appendString:@"+++"]; NSLog(@"newStr sting:%@", newStr); NSLog(@"retain sting:%@", self.retainStr); NSLog(@"strong string:%@", self.strongStr); NSLog(@"copy string:%@", self.copStr);}
结果
2017-03-15 11:21:37.418 AppDemo[58848:4000958] newStr sting:abcd
2017-03-15 11:21:37.419 AppDemo[58848:4000958] retain sting:abcd 2017-03-15 11:21:37.419 AppDemo[58848:4000958] strong string:abcd 2017-03-15 11:21:37.419 AppDemo[58848:4000958] copy string:abcd 2017-03-15 11:21:37.419 AppDemo[58848:4000958] ------------ 2017-03-15 11:21:37.420 AppDemo[58848:4000958] newStr sting:abcd123 2017-03-15 11:21:37.420 AppDemo[58848:4000958] retain sting:abcd123 2017-03-15 11:21:37.420 AppDemo[58848:4000958] strong string:abcd123 2017-03-15 11:21:37.420 AppDemo[58848:4000958] copy string:abcd 2017-03-15 11:21:37.420 AppDemo[58848:4000958] ------------ 2017-03-15 11:21:37.421 AppDemo[58848:4000958] newStr sting:(null) 2017-03-15 11:21:37.421 AppDemo[58848:4000958] retain sting:abcd123 2017-03-15 11:21:37.421 AppDemo[58848:4000958] strong string:abcd123 2017-03-15 11:21:37.421 AppDemo[58848:4000958] copy string:abcd 2017-03-15 11:21:37.421 AppDemo[58848:4000958] ------------ 2017-03-15 11:21:37.422 AppDemo[58848:4000958] newStr sting:(null) 2017-03-15 11:21:37.422 AppDemo[58848:4000958] retain sting:abcd123 2017-03-15 11:21:37.422 AppDemo[58848:4000958] strong string:abcd123 2017-03-15 11:21:37.422 AppDemo[58848:4000958] copy string:abcd
2. strong,weak
strong与weak是由ARC新引入的对象变量属性
强引用与弱引用的广义区别:
强引用也就是我们通常所讲的引用,其存亡直接决定了所指对象的存亡。如果不存在指向一个对象的引用,并且此对象不再显示列表中,则此对象会被从内存中释放。 弱引用除了不决定对象的存亡外,其他与强引用相同。即使一个对象被持有无数个弱引用,只要没有强引用指向他,那麽其还是会被清除。没办法,还是 “强哥” 有面子。简单讲strong等同retain
weak比assign多了一个功能,当对象消失后自动把指针变成nil,好处不言而喻。在使用时,一般用 asssign 处理 int, double, NSInteger等原子类型, weak 指向 代理,弱引用对象等.
3. __weak, __strong
__weak, __strong 用来修饰变量,此外还有 __unsafe_unretained, __autoreleasing 都是用来修饰变量的。
__strong 是缺省的关键词(定义变量时的默认属性)。 __weak 声明了一个可以自动 nil 化的弱引用。 __unsafe_unretained 声明一个弱应用,但是不会自动nil化,也就是说,如果所指向的内存区域被释放了,这个指针就是一个野指针了。(既然这么危险,为什么还要用??? 这里给了很好的回答: https://www.zhihu.com/question/55831650?sort=created )
__autoreleasing 用来修饰一个函数的参数,这个参数会在函数返回的时候被自动释放。
assign: setter方法直接赋值,不进行任何retain操作
retain: setter方法对参数进行release旧值再retain新值,所有实现都是这个顺序
copy: setter方法进行Copy操作,与retain处理流程一样,先旧值release,再Copy出新的对象,retainCount为1。这是为了减少对上下文的依赖而引入的机制。
nonatomic : 非原子性访问,不加同步,多线程并发访问会提高性能。注意,如果不加此属性,则默认是两个访问方法都为原子型事务访问。锁被加到所属对象实例级.所以 不加nonatomic对与多线程是安全的 。