ios中的@property和@synthesize

来源:互联网 发布:金山画王软件大小 编辑:程序博客网 时间:2024/05/05 06:58

在@property中的关键字,它们都是有特殊作用的,我把它们分为三类分别是:原子性,访问器控制,内存管理。

原子性

atomic(默认):atomic意为操作是原子的,意味着只有一个线程访问实例变量。atomic是线程安全的至少在当前的访器上我是安全的。它是一个默认的,但是很少使用。它的比较慢,这跟ARM平台和内部锁机制有关。

nonatomic: nonatomic跟atomic刚好相反。表示非原子的,可以被多个线程访问。它的速度比atomic快。但不能保证在多线程环境下的安全性,在单线程和明确只有一个线程访问的情况下广泛使用。

访问器控制

readwrite(默认):readwrite是默认的,表示同时拥有setter和getter。

readonly: readonly 表示只有getter没有setter。

内存管理

retain:使用了retain意味着实例变量要获取传入参数的所有权。具体表现在setter中对实例变量先release然后将参数 retain之后传给它。下面这段代码展示了retain类似的行为:

  1. -(void)setStuName:(NSString *)stuName 
  2.       { 
  3.          if (_stuName != stuName) 
  4.          { 
  5.             [_stuName release]; 
  6.              _stuName = [stuName retain]; 
  7.          } 
  8.       } 

NSString *pt = [[NSString alloc] initWithString:@"abc"];
上面一段代码会执行以下两个动作
1 在堆上分配一段内存用来存储@"abc"  比如:内存地址为:0X1111 内容为 "abc"
2 在栈上分配一段内存用来存储pt  比如:地址为:0Xaaaa 内容自然为0X1111  

assign的情况:NSString *newPt = [pt assing];  
此时newPt和pt完全相同 地址都是0Xaaaa  内容为0X1111  即newPt只是pt的别名,对任何一个操作就等于对另一个操作。 因此retainCount不需要加。

retain的情况:NSString *newPt = [pt retain];  
此时newPt的地址不再为0Xaaaa,可能为0Xaabb 但是内容依然为0X1111。 因此newPt 和 pt 都可以管理"abc"所在的内存。因此 retainCount需要增加1  
copy的情况:NSString *newPt = [pt copy];
此时会在堆上重新开辟一段内存存放@"abc" 比如0X1122 内容为@"abc 同时会在栈上为newPt分配空间 比如地址:0Xaacc 内容为0X1122 因此retainCount增加1供newPt来管理0X1122这段内存

strong:是在ARC伴随IOS引入的时候引入的关键字是retain的一个可选的替代。表示实例变量对传入的参数要有所有权关系即强引用。strong跟retain的意思相同并产生相同的代码,但是语意上更好更能体现对象的关系。

weak: weak跟assign的效果相似,不同的是weak在对象被回收之后自动设置为nil。而且weak智能用在iOS 5或以后的版本,对于之前的版本,使用unsafe_unretained。

unsafe_unretained:weak的低版本替代。  

@synthesize目前的xcode不需要这个也可以有setter等。




0 0
原创粉丝点击