iOS开发之详谈属性设置readwrite、readonly、retain、copy、assign、nonatomic
具体详细介绍请看下文文字说明吧,本文介绍的非常详细。
1.可读性:readonly、readwrite
@property(readwrite,....)valueTypevalue;
这个属性是变量的默认属性,就是如果你(readwriteandreadonly都没有使用,那么你的变量就是readwrite属性),通过加入readwrite属性你的变量就会有get和set方法。
property(readonly,...)valueTypevalue;
这个属性变量就是表明变量只有可读方法,也就是说,你只能使用它的get方法。
2.assign,setter方法直接赋值,不进行任何retain操作,为了解决原类型与环循引用问题
3.retain,setter方法对参数进行release旧值再retain新值,所有实现都是这个顺序
4.copy,setter方法进行Copy操作,与retain处理流程一样,先旧值release,再copy出新的对象,retainCount为1。这是为了减少对上下文的依赖而引入的机制。
5.nonatomic,非原子性访问,不加同步,多线程并发访问会提高性能。
注意,如果不加此属性,则默认是两个访问方法都为原子型事务访问。锁被加到所属对象实例级。所以不加nonatomic对与多线程是安全的。
6.retainvs.Copy
copy :建立一个索引计数为1的对象,然后释放旧对象
retain:释放旧的对象,将旧对象的值赋予输入对象,再提高输入对象的索引计数为1
那上面的是什么该死的意思呢?
copy其实是建立了一个相同的对象,而retain不是:
比如定义如下属性:
@property(copy,nonatomic)NSString*testStr;
使用方法如下:
NSMutableString*str3=[[NSMutableStringalloc]initWithString:@"MutableString" self.testStr=str3; NSLog(@"%d",[self.testStrretainCount]); NSLog(@"%d",[str3retainCount]);
可以看到testStr和str3地址不同,retainCount都是1
如果把copy改为retain,那么他们指向相同的地址,retainCount为2.
明白了吧,retain是指针copy,指向同一地址,计数加1,而copy是把内容复制过来。
Objective-C属性特性(assign,retain,copy,readonly,readwrite,atomic,nonatomic)
assign:指定setter方法用简单的赋值,这是默认操作。你可以对标量类型(如int)使用这个属性。你可以想象一个float,它不是一个对象,所以它不能retain、copy。
retain:指定retain应该在后面的对象上调用,前一个值发送一条release消息。你可以想象一个NSString实例,它是一个对象,而且你可能想要retain它。
copy:指定应该使用对象的副本(深度复制),前一个值发送一条release消息。基本上像retain,但是没有增加引用计数,是分配一块新的内存来放置它。
readonly:将只生成getter方法而不生成setter方法(getter方法没有get前缀)。
readwrite:默认属性,将生成不带额外参数的getter和setter方法(setter方法只有一个参数)。
atomic:对于对象的默认属性,就是setter/getter生成的方法是一个原子操作。如果有多个线程同时调用setter的话,不会出现某一个线程执行setter全部语句之前,另一个线程开始执行setter的情况,相关于方法头尾加了锁一样。
nonatomic:不保证setter/getter的原子性,多线程情况下数据可能会有问题。
以上内容是小编给大家介绍的iOS开发之详谈属性设置readwrite、readonly、retain、copy、assign、nonatomic,希望大家喜欢。