OC中的關鍵字,@property與@synthesize配對使用。
文法:
@property (參數1,參數2) 變數類型 變數名
@synthesize 變數名
功能:
讓編譯器自動編寫一個與資料成員同名的方法聲明,這樣可以省去聲明讀寫方法。
例如:
// 在標頭檔中@property NSInteger number;// 在實現檔案中@synthesize number;
等同於:
// 在標頭檔中- (void)setNumber:(NSInteger)newNumber;- (NSInteger)number;// 在實現檔案中- (void)setNumber:(NSInteger)newNumber{number = newNumber;}- (NSInteger)number{return number;}
顯而易見,用@property和@synthesize減少了大量的工作量。
參數有以下幾種:
nonatomic :原子性,變數保護,禁止多線程,提高效能
atomic : 意義與nonatomic相反
retain : setter方法對參數進行release舊值,在retain新值
copy :setter方法進行Copy操作,與retain一樣
assign :setter方法直接進行賦值,不進行retain操作
readonly :只產生簡單的getter,不聲稱setter方法
readwrite :產生setter和getter方法
atomic的意思就是setter/getter這個函數是一個原語操作。如果有多個線程同時調用setter的話,不會出現某一個線程執行setter全部語句之前,另一個線程開始執行setter情況,相當於函數頭尾加了鎖一樣。
nonatomic不保證setter/getter的原語操作,所以你可能會取到不完整的東西。比如setter函數裡面改變兩個成員變數,如果你用nonatomic的話,getter可能會取到只更改了其中一個變數時候的狀態,這樣取到的東西會有問題。如果不需要多線程支援的話,當然nonatomic就夠用了,另外由於不涉及鎖操作,所以它執行相對快點
舉例說明:
1. retain
@property (nonatomic, retain) Class *aClass;@synthesize aClass;// 等同於:- (void)setAClass:(Class *)_aClass{if(aClass !=_aClass ){[aClass release];aClass = [_aClass retain];}}- (Class *)aClass{return aClass;}
2.retain
@property (retain) Class *aClass;@synthesize aClass;// 等同於:- (void)setAClass:(Class *)_aClass{if(aClass !=_aClass ){[aClass release];aClass = [_aClass retain];}}- (Class *)aClass{ [aClass retain];return [aClass autorelease];}
3.copy
@property (nonatomic, copy) Class *aClass;@synthesize aClass;// 等同於:- (void)setAClass:(Class *)_aClass{if(aClass !=_aClass ){[aClass release];aClass = [_aClass copy];}}- (Class *)aClass{return aClass;}
4.copy
@property (copy) Class *aClass;@synthesize aClass;// 等同於:- (void)setAClass:(Class *)_aClass{if(aClass !=_aClass ){[aClass release];aClass = [_aClass copy];}}- (Class *)aClass{ [aClass retain];return [aClass autorelease];}