属性机制(@property)可以使我们不需要在.h中声明存取方法,不需要在.m中实现存取方法,使用@synthesize即可。
属性的特性:
存取类型:
任何一个属性可以声明为readwrite或readonly,默认为readwrite
生命周期类型:
包括:unsafe_unretained、strong、weak、cop决定村方法将如何处理与其相关的内存管理问题
unsafe_unretained:默认,存方法会将传入的值直接赋给实例变量。凡是非对象类型的实例变量,都应该使用该特性。
strong:要求保留传入的对象。凡事只想对象的实例变量,通常都应该使用strong特性。
weak:要求不保留传入的对象。相应的存方法会将传入的对象直接赋给实例变量。如果该对象被释放,那么相应的实例变量会被自动赋为nil(unsafe_unretained在对象释放后会成为空指针)
copy:要求拷贝传入的对象,并将新对象赋给实例变量。
-(void)setLastName:(NSString *)d{
lastName = [d copy];
}
有可修改的子类的对象适合用copy特性。例如,NSString的NSMutableString子类。
执行如下代码:
会输出如下结果:
因为setLastName方法会拷贝传入的对象,所以修改x不会对实例变量产生影响。
atomic和nonatomic:
调用通过属性机制自动生成的村方法时,如果相关的属性带有noatomic,那么调用速度会快一点。默认为atomic,但是多数情况下使用noatomic。
KVC:
能够直接让程序通过名称直接存取属性。例,[a setValue:@“Washing Machine” forKey:@“productName"];
setValue:forKey:方法会查找名为setProductName:的方法,如果对象a没有,就会直接为实例变量赋值。
也可以使用KVC读取实例变量。例,NSLog(@“the product name is %@”,[a valueForKey:@“productName"]);
如果输错了属性名,变异不会发出警告,但运行会发生错误。
KVC可以在没有存取方法的情况下直接存取实例变量。KVC是对象封装的一个例外(对象的方法可以公开,但是实例变量应该保持私有)。
非对象类型:KVC只对对象有效,对于不是对象的属性,如int或float类型,KVC使用NSNumber。例,
[a setValue:[NSNumber numberWithInt:240] forKey:@“voltage”];
如果是取方法,返回的将是NSNumber,包含voltage的值。