strong,weak, retain, assign的區別

 

strong與weak是由ARC新引入的對象變量屬性 ios

xcode 4.2(ios sdk4.3和如下版本)和以前的版本使用的是retain和assign,是不支持ARC的。xcode 4.3(ios5和以上版本)以後就有了ARC,而且開始使用 程序員

strong與weak 數組

 

 

 

 

assign: 用於非指針變量。用於 xcode

基礎數據類型 (例如NSInteger)和C數據類型(int, float, double, char, 等),另外還有id 安全

如: 多線程

@property (nonatomic, assign) int number; atom

@property (nonatomic, assign) id className;//id必須用assign spa

反正記住:前面不須要加 「*」 的就用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,不須要手動釋放內存,系統會自動爲你完成,若是你在xcode4.3上面開發,retian和strong都是同樣的,沒區別 

 

 

strong和weak: 

事實上 

@property(nonatomic,strong) MyClass *myObject;就是至關於@property(nonatomic,retain) MyClass *myObject;@property(nonatomic, weak )id<RNNewsFeedCellDelegate>delegate;就是至關於@property(nonatomic,assign )id<RNNewsFeedCellDelegate>delegate; 

如今系統自動生成的屬性都是用weak來修飾的,我想應該是xcode 4.2不支持ARC,因此你們都是用retain。如今xcode4.3支持ARC了,因而蘋果建議程序員放棄retain,之後都用weak。 

weak 就是至關於assign,一樣能夠在xcode4.3開發環境下放棄使用assign 使用weak 來代替 

 

 

2.unsafe_unretained 

unsafe_unretained 就是ios5版本如下的 assign ,也就是 unsafe_unretained , weak, assign 三個都是一個樣的。 由於 ios5用的是 weak ,那在ios4.3就用不了,若是你將 weak 修改成 unsafe_unretained ,那就能夠用了。說到底就是iOS 5以前的系統用該屬性代替 weak 來使用。 

 

 

copy:這個東西估計是大部分人最不容易搞明白的東西,我也搞不明白。聽別人說這個東西基本不用了,效果其實和retain沒什麼兩樣,惟一的區別就是copy只用於NSString而不能用於NSMutableString。 

不過好像當一個類繼承NSObject,那麼這個類裏面的屬性須要使用copy,好比: 

#import <Foundation/Foundation.h> 

#import <MapKit/MKAnnotation.h> 

@interface Annotation : NSObject <MKAnnotation> { 

        

        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開發程序的程序員會習慣用retain ,因此代碼都是retian的,新手若是從xcode4.3學起的話就用strong與weak  吧,這裏面講的區別有些不對的地方。 

 

readonly 

此標記說明屬性是隻讀的,默認的標記是讀寫,若是你指定了只讀,在@implementation中只須要一個讀取器。或者若是你使用@synthesize關鍵字,也是有讀取器方法被解析。並且若是你試圖使用點操做符爲屬性賦值,你將獲得一個編譯錯誤。 

 

readwrite 

此標記說明屬性會被當成讀寫的,這也是默認屬性。設置器和讀取器都須要在@implementation中實現。若是使用@synthesize關鍵字,讀取器和設置器都會被解析。 

 

assign 

此標記說明設置器直接進行賦值,這也是默認值。在使用垃圾收集的應用程序中,若是你要一個屬性使用assign,且這個類符合NSCopying協議,你就要明確指出這個標記,而不是簡單地使用默認值,不然的話,你將獲得一個編譯警告。這再次向編譯器說明你確實須要賦值,即便它是可拷貝的。 

 

retain 

指定retain會在賦值時喚醒傳入值的retain消息。此屬性只能用於Objective-C對象類型,而不能用於Core Foundation對象。(緣由很明顯,retain會增長對象的引用計數,而基本數據類型或者Core Foundation對象都沒有引用計數——譯者注)。 

 

copy 

它指出,在賦值時使用傳入值的一份拷貝。拷貝工做由copy方法執行,此屬性只對那些實行了NSCopying協議的對象類型有效。更深刻的討論,請參考「複製」部分。 

 

nonatomic 

指出訪問器不是原子操做,而默認地,訪問器是原子操做。這也就是說,在多線程環境下,解析的訪問器提供一個對屬性的安全訪問,從獲取器獲得的返回值或者經過設置器設置的值能夠一次完成,即使是別的線程也正在對其進行訪問。若是你不指定nonatomic,在本身管理內存的環境中,解析的訪問器保留並自動釋放返回的值,若是指定了nonatomic,那麼訪問器只是簡單地返回這個值。

相關文章
相關標籤/搜索