申明属性
属性使用@property声明,默认是会自动生成get 和set 方法的
点访问(self.*)实际上调用了生成的 get 和 set 方法
默认已经自动生成了两个方法
-(void)setCarNumber:(NSString *)carNumber;
-(void)getCarNumber:(NSString *)carNumber;
并且会自动生变量,_carNumber
@synthesize carNumber = _carNumber; (Xcode4.5以后会自动加上,synthesize可以让编译器自动实现getter/setter方法 )
属性特征有: readonly、readwrite(默认值)、assign(默认值)、retain、copy、nonatomic、atomic(默认)
——
申明属性为readonly时,只会生成get方法。如果要改变值,只能使用_carNumber = @"D56413" 这样的方式完成赋值。不可使用"."的方式赋值,如:使用self.carNumber = @"D56413"是不允许的。
@property(readonly) NSString *carNumber;
-(void)getCarNumber:(NSString *)carNumber;方法
——
使用retain时,设置car.carNumber 计数器都会自动+1
接下来使用可能有两种情况
1. car.carNumber= nil; carNumber 会自动释放,并且计数器自动-1;
2. car.carNumber = @“newNumber”; carNumber 会先-1,释放carNumber,在把 @“newNumber” 赋值给carNumber 计数器自动+1。
实际做的事类似如下
-(void)setCarNumber:(NSString *)carNumber
{
if (_carNumber != carNumber) {
[_carNumber release];
_carNumber = [carNumber retain];
}
}
——
copy 和retain 类似
——
atomic,这种情况下生成的访问器是原子操作,在多线程环境下,解析的访问器提供一个对属性的安全访问。
——
nonatomic,使用原子操作,访问器只是简单地返回这个值,不提供线程安全。
以上是个人理解,如有出入,还请指出,多谢!
本文详细解释了如何在Objective-C中通过@properties声明属性,包括默认的getter和setter方法生成,readonly属性的使用限制,以及retain、copy等属性特征的影响。同时讨论了属性在不同访问权限下(readonly、readwrite)的行为差异,以及在多线程环境下的原子操作处理。

1万+

被折叠的 条评论
为什么被折叠?



