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,那麼訪問器只是簡單地返回這個值。