一、assign (ARC/MRC)
1、assign在ARC和MRC中都是存在的
2、assign一般用来修饰基本数据类型
3、assign也可用来修饰对象,但是,对象的引用计数不会+1(与strong的区别)
4、assign如果用来修饰对象属性,当对象销毁后指针不会指向nil,会出现野指针错误(与weak的区别)
5、在MRC用assign来修饰代理,是为了防止循环引用。
二、weak(ARC)
1、弱指针是针对对象的修饰词 , 就是说它不能修饰基本数据类型 。
2、weak修饰的对象,引用计数不会+1,即直接赋值
3、弱引用是为打破循环引用而生的
4、它所指向的对象如果被销毁 , 它会指向 nil . 而 nil 访问什么鬼都不会报野指针错误 .
三、strong(ARC)
1、直接赋值,对象引用计数+1
2、功能等价于MRC里面的retain
四、copy(ARC/MRC)
在 ARC 中copy情况比较复杂例如
1.对一个不可变数组copy,不会产生新数组,原数组计数器+1,且新数组是不可变数组
2.对一个可变数组copy,会产生新数组,并且新数组是不可变数组
NSArray *firstArr = @[@"one",@"two",@"three"];
NSArray *firstArrCopy = [firstArr copy];
NSMutableArray *firstArrMytableCopy = [firstArr mutableCopy];
NSLog(@"%p %p %p",firstArr,firstArrCopy,firstArrMytableCopy);
打印如下 0x608000051070 0x608000051070 0x608000050860
po [firstArrMytableCopy class]
__NSArrayM
四、mutableCopy(ARC/MRC)
在 ARC 中mutableCopy情况比较复杂例如
1.对一个不可变数组mutableCopy,会产生新数组,且新数组是可变数组
2.对一个可变数组mutableCopy,会产生新数组,并且新数组是可变数组
NSMutableArray *Sarr [NSMutableArrayarrayWithObjects:@"one",@"two",@"three", nil];
NSArray *SarrCopy = [Sarr copy];
NSLog(@"copySecond %p %p",Sarr,SarrCopy);
打印结果如下:copySecond 0x600000050110 0x60000004f810
po [SarrCopy class]
__NSArrayI
(不可变数组)
五、原子属性(atomic)和非原子属性(nonatomic)(ARC/MRC)
非原子属性(nonatomic):
1、不对set方法加锁(@synchronized),互斥锁是利用线程同步实现的 , 意在保证同一时间只有一个线程调用 set 方法 。
2、性能好
3、线程不安全
原子属性(atomic):
1、原子属性就是对生成的 set 方法加互斥锁 @synchronized(锁对象)
2、需要消耗系统资源
3、还有 get 方法 , 要是同时 set 和 get 一起调用还是会有问题的 . 所以即使用了 atomic 修饰 还是不够安全 .
六、readOnly(只读)、readWrite(读写)
readOnly:
1、只读属性,意味着只合成getter方法
2、不想把暴露的属性被别人替换,可以使用readOnly修饰
readWrite:
1、生成getter和setter方法
2、不用readOnly修饰时候,默认为readWrite
七、static
用static声明局部变量时,则改变变量的存储方式(生命期),使变量成为静态的局部变量,即编译时就为变量分配内存,直到程序退出才释放存储单元。这样,使得该局部变量有记忆功能,可以记忆上次的数据,不过由于仍是局部变量,因而只能在代码块内部使用(作用域不变)。