strong與weak是由ARC新引入的對象變量屬性
xcode 4.2(ios sdk4.3和以下版本)和之前的版本使用的是retain和assign,是不支持ARC的。xcode 4.3(ios5和以上版本)之后就有了ARC,并且開始使用
strong與weak
assign: 用于非指針變量。用于
基礎數據類型 (例如NSInteger)和C數據類型(int, float, double, char, 等),另外還有id
如:
@property (nonatomic, assign) int number;
@property (nonatomic, assign) id className;//id必須用assign
反正記住:前面不需要加 “*” 的就用assign吧
retain:用于指針變量。就是說你定義了一個變量,然后這個變量在程序的運行過程中會被更改,并且影響到其他方法。一般是用于字符串( NSString,NSMutableString),數組(NSMutableArray,NSArray),字典對象,視圖對象(UIView ),控制器對象(UIViewController)等
比如:
@property (nonatomic,retain) NSString * myString;
@property (nonatomic, retain) UIView * myView;
@property (nonatomic, retain) UIViewController * myViewController;
xcode 4.2不支持ARC,所以會頻繁使用retain來修飾,用完釋放掉,而xcode4.3支持ARC,可以使用retian,不需要手動釋放內存,系統(tǒng)會自動為你完成,如果你在xcode4.3上面開發(fā),retian和strong都是一樣的,沒區(qū)別
strong和weak:
事實上
@property(nonatomic,strong) MyClass *myObject;就是相當于@property(nonatomic,retain) MyClass *myObject;@property(nonatomic, weak )iddelegate;就是相當于@property(nonatomic,assign )iddelegate;
現(xiàn)在系統(tǒng)自動生成的屬性都是用weak來修飾的,我想應該是xcode 4.2不支持ARC,所以大家都是用retain。現(xiàn)在xcode4.3支持ARC了,于是蘋果建議程序員放棄retain,以后都用weak。
weak 就是相當于assign,同樣可以在xcode4.3開發(fā)環(huán)境下放棄使用assign 使用weak 來代替
unsafe_unretained
unsafe_unretained 就是ios5版本以下的 assign ,也就是 unsafe_unretained , weak, assign 三個都是一個樣的。 因為 ios5用的是 weak ,那在ios4.3就用不了,如果你將 weak 修改為 unsafe_unretained ,那就可以用了。說到底就是iOS 5之前的系統(tǒng)用該屬性代替 weak 來使用。
copy:這個東西估計是大部分人最不容易搞明白的東西,我也搞不明白。聽別人說這個東西基本不用了,效果其實和retain沒什么兩樣,唯一的區(qū)別就是copy只用于NSString而不能用于NSMutableString。
不過好像當一個類繼承NSObject,那么這個類里面的屬性需要使用copy,比如:
#import
#import
@interface Annotation : NSObject {
CLLocationCoordinate2D coordinate;
NSString *title;
NSString *subtitle;
}
@property (nonatomic) CLLocationCoordinate2D coordinate;
@property (nonatomic, copy) NSString *title;
@property (nonatomic, copy) NSString *subtitle;
@end
反正以后就這么用就是了
反正就記住一點:xcode4.2用retain和assign ;xcode4.3或以上版本用strong與weak 。以前用xcode4.2開發(fā)程序的程序員會習慣用retain ,所以代碼都是retian的,新手如果從xcode4.3學起的話就用strong與weak? 吧,這里面講的區(qū)別有些不對的地方。
readonly
此標記說明屬性是只讀的,默認的標記是讀寫,如果你指定了只讀,在@implementation中只需要一個讀取器。或者如果你使用@synthesize關鍵字,也是有讀取器方法被解析。而且如果你試圖使用點操作符為屬性賦值,你將得到一個編譯錯誤。
readwrite
此標記說明屬性會被當成讀寫的,這也是默認屬性。設置器和讀取器都需要在@implementation中實現(xiàn)。如果使用@synthesize關鍵字,讀取器和設置器都會被解析。
assign
此標記說明設置器直接進行賦值,這也是默認值。在使用垃圾收集的應用程序中,如果你要一個屬性使用assign,且這個類符合NSCopying協(xié)議,你就要明確指出這個標記,而不是簡單地使用默認值,否則的話,你將得到一個編譯警告。這再次向編譯器說明你確實需要賦值,即使它是可拷貝的。
retain
指定retain會在賦值時喚醒傳入值的retain消息。此屬性只能用于Objective-C對象類型,而不能用于Core Foundation對象。(原因很明顯,retain會增加對象的引用計數,而基本數據類型或者Core Foundation對象都沒有引用計數——譯者注)。
copy
它指出,在賦值時使用傳入值的一份拷貝。拷貝工作由copy方法執(zhí)行,此屬性只對那些實行了NSCopying協(xié)議的對象類型有效。更深入的討論,請參考“復制”部分。
nonatomic
指出訪問器不是原子操作,而默認地,訪問器是原子操作。這也就是說,在多線程環(huán)境下,解析的訪問器提供一個對屬性的安全訪問,從獲取器得到的返回值或者通過設置器設置的值可以一次完成,即便是別的線程也正在對其進行訪問。如果你不指定nonatomic,在自己管理內存的環(huán)境中,解析的訪問器保留并自動釋放返回的值,如果指定了nonatomic,那么訪問器只是簡單地返回這個值。
所以property的屬性默認是:readwrite,assign, atomic(沒有這個關鍵字)