readwrite、readonly、retain、copy、assign、nonatomic的作用以及使用场景

1 可读性: readonly、readwrite

@property(readwrite,....) valueType value;

这个属性是变量的默认属性,就是如果你 (readwrite and readonly 都没有使用,那么你的变量就是 readwrite属性 ) ,通过加入 readwrite 属性你的变量就会有 get  set 方法。

property(readonly,...) valueType value;

这个属性变量就是表明变量只有可读方法,也就是说,你只能使用它的 get 方法。

2 . assign , setter 方法直接赋值,不进行任何 retain 操作,为了解决原类型与环循引用问题

3 retain , setter 方法对参数进行 release 旧值再 retain 新值,所有实现都是这个顺序

4 copy setter 方法进行 Copy 操作,与 retain 处理流程一样,先旧值 release ,再 copy 出新的对象,retainCount  1 。这是为了减少对上下文的依赖而引入的机制。

5 .nonatomic ,非原子性访问,不加同步,多线程并发访问会提高性能。

注意,如果不加此属性,则默认是两个访问方法都为原子型事务访问。锁被加到所属对象实例级 。 所以不加nonatomic 对与多线程是安全的 

6 . retain vs. Copy

copy   :建立一个索引计数为 1 的对象,然后释放旧对象

retain :释放旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为 1

那上面的是什么该死的意思呢?

copy 其实是建立了一个相同的对象,而 retain 不是:

比如定义如下属性:

 

[代码]c#/cpp/oc代码:

@property (copy, nonatomic) NSString *testStr;

使用方法如下:

 

[代码]c#/cpp/oc代码:

 

 

01 NSMutableString *str3 =[[NSMutableString alloc ]initWithString:@"Mutable String"
05 self.testStr = str3;
09 NSLog(@"%d", [self.testStr retainCount]);
11 NSLog(@"%d", [str3 retainCount]);

可以看到testStr和str3地址不同,retainCount都是1

如果把copy改为retain,那么他们指向相同的地址,retainCount为2.

明白了吧,retain是指针copy,指向同一地址,计数加1,而copy是把内容复制过来。

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值