屬性設(shè)置readwrite、readonly、retain、copy、assign、nonatomic

1 . 可讀性: readonly、readwrite

@property(readwrite,....) valueType value;

這個(gè)屬性是變量的默認(rèn)屬性,就是如果你 (readwrite and readonly 都沒有使用,那么你的變量就是 readwrite屬性 ) ,通過(guò)加入 readwrite 屬性你的變量就會(huì)有 get 和 set 方法。

property(readonly,...) valueType value;

這個(gè)屬性變量就是表明變量只有可讀方法,也就是說(shuō),你只能使用它的 get 方法。

2 . assign , setter 方法直接賦值,不進(jìn)行任何 retain 操作,為了解決原類型與環(huán)循引用問(wèn)題

3 . retain , setter 方法對(duì)參數(shù)進(jìn)行 release 舊值再 retain 新值,所有實(shí)現(xiàn)都是這個(gè)順序

4 . copy ,setter 方法進(jìn)行 Copy 操作,與 retain 處理流程一樣,先舊值 release ,再 copy 出新的對(duì)象,retainCount 為 1 。這是為了減少對(duì)上下文的依賴而引入的機(jī)制。

5 .nonatomic ,非原子性訪問(wèn),不加同步,多線程并發(fā)訪問(wèn)會(huì)提高性能。

注意,如果不加此屬性,則默認(rèn)是兩個(gè)訪問(wèn)方法都為原子型事務(wù)訪問(wèn)。鎖被加到所屬對(duì)象實(shí)例級(jí) 。 所以不加nonatomic 對(duì)與多線程是安全的 。

6 . retain vs. Copy

copy? :建立一個(gè)索引計(jì)數(shù)為 1 的對(duì)象,然后釋放舊對(duì)象

retain :釋放舊的對(duì)象,將舊對(duì)象的值賦予輸入對(duì)象,再提高輸入對(duì)象的索引計(jì)數(shù)為 1

那上面的是什么該死的意思呢?

copy 其實(shí)是建立了一個(gè)相同的對(duì)象,而 retain 不是:

比如定義如下屬性:

[代碼]c#/cpp/oc代碼:

@property (copy, nonatomic) NSString *testStr;

使用方法如下:

[代碼]c#/cpp/oc代碼:

01 NSMutableString *str3 =[[NSMutableString alloc ]initWithString:@"Mutable String"

05 self.testStr = str3;

09 NSLog(@"%d", [self.testStr retainCount]);

11 NSLog(@"%d", [str3 retainCount]);

可以看到testStr和str3地址不同,retainCount都是1

如果把copy改為retain,那么他們指向相同的地址,retainCount為2.

明白了吧,retain是指針copy,指向同一地址,計(jì)數(shù)加1,而copy是把內(nèi)容復(fù)制過(guò)來(lái)。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

推薦閱讀更多精彩內(nèi)容