属性以及它的特性
1.属性的赋值与取值
书上面的解释就是使用点运算符来访问属性,可以操作属性来进行赋值与取值。按照字面意思来理解,你可能觉得只是使用点运算符来简单的操作定义属性时生成的实例变量,实则不然。按照书上讲的,点运算符操作属性的同时,也具有调用方法的功能。按照这样理解,点运算符的右侧跟什么方法名,就调用的是哪个方法。但细心的人会发现,之前我们经常用的一个例子违反了这一个规则。这个例子出现在属性这部分之前,它首先定义了一个实例变量,再给这个实例变量设置一个存取方法(如实例变量origin,再分别定义两个方法:origin和setOrigin),书上说这个例子等价于你直接定义一个origin属性。那么,接下来,我们观察,按照之前的规则,如果我们使用点运算符右边跟一个origin,那么会有两个问题产生:第一,我们到底调用的是origin变量还是origin方法呢;第二,如果调用的时origin方法,而origin方法是一个取值方法,也就是说我们只能将它返回的值赋给其他的同类型变量,可是我们在书上却见到将其他的值赋给它。思考这两个问题,假如是调用变量,那么那两个方法该如何解释呢?因此可以确定,点运算符调用的是方法。那么问题又来了,如果是调用方法的话,那么为什么将一个取值方法作为一个赋值运算符的左侧对象来使用呢?说道这里,你可能会想到,这不正是设置方法的功能吗?答案是肯定的。如果点运算符后面跟origin,如果对它赋值,实际上调用的是setOrigin方法。
2.特性
oc中的属性特征主要有assign,copy,retain这三个主要的,还有readonly,readwrite. 另外,atomic和nonatomic;以及strong,weak。
assign主要是针对基础类型数据和c数据类型的简单赋值,而且它不调用索引计数器(retain count)。
retain主要是指调用oc中的对象,对oc中的对象进行赋值(主要针对NSObject及其子类),需要调用索引计数器(retain count)进行+1操作,开辟新的内存空间,在赋予新值之后便进行release操作。
copy是指使用对象的副本,索引计数器的计数依旧保持为1,它只是为对象创建了一个新的指针,指向内存相应位置的对象,并没有开辟新的内存空间(此时的复制为浅复制)。
readonly是只生成getter方法,而不生成setter方法,就是只读存储。
readwrite是默认属性,将生成不带额外参数的getter和setter方法。
assign是一种原子访问,如果有多个线程调用setter方法的话,不会出现在一个线程调用setter没有完成之前,另一个线程开始调用setter这个方法,可以讲该属性锁定。
nonassign是非原子访问,不加同步和多线程,不进行锁定,当出现多线程的时候,会出现问题,但是这样相对提高了性能。
最后
特性不能用于有参数的setter和getter方法,假如要有参数的setter和getter方法的话,则必须重写setter和getter方法如:
(void) setTest: (Tire *) tire atIndex: (int) index;
(Tire *) tireAtIndex: (int) index;
_郭挺