@property 后面都有哪些修飾符

1、readwrite / readonly
readwrite: 讀寫(xiě),系統(tǒng)會(huì)自動(dòng)創(chuàng)建 setter 和 getter 方法;
readonly: 只讀,系統(tǒng)只會(huì)創(chuàng)建 getter 方法,而不會(huì)創(chuàng)建 setter 方法;

2、Xcode 4.2(iOS sdk4.3和以下版本)和之前的版本用的 retain 和
assign ;
Xcode 4.3 (iOS 5 和以上版本)之后的版本(ARC)用的都是 strong 和 weak ;
strong 類似于 retain, weak 類似于 assign。

3、原子性修飾符: atomic / nonatomic
atomic:表示是線程安全的;
nonatomic:表示是非線程安全的,使用此屬性性能會(huì)提高一些。
系統(tǒng)默認(rèn)是 atomic

aotmic 是指屬性的存取方法是線程安全的( thread safe ),并不保證整個(gè)對(duì)象是線程安全的。比如,聲明一個(gè) NSMutableArray 的原子屬性 stuff,此時(shí) self.stuff 和 self.stuff = otherstuff 都是線程安全的,但是,使用 [self.stuff objectAtIndex:index]; 就不是線程安全的,需要用線程鎖來(lái)保證線程安全性。

4、setter 相關(guān)修飾符: assign / retain / copy
assign:表示直接賦值,用于基本類型( NSInteger 和 CGFloat )和 C數(shù)據(jù)類型( int ,float,double,char 等),另外還有 id 類型,這個(gè)修飾符不會(huì)牽扯到內(nèi)存管理,但是如果是對(duì)象類型,使用此修飾符則可能會(huì)導(dǎo)致內(nèi)存泄漏 或者 EXE_BAD_ACCESS 錯(cuò)誤。

retain:針對(duì)對(duì)象類型進(jìn)行內(nèi)存管理。如果對(duì)基本數(shù)據(jù)類型使用,則 Xcode 會(huì)直接報(bào)錯(cuò)。當(dāng)給對(duì)象類型使用此修飾符時(shí),setter 方法會(huì)先將舊的對(duì)象屬性 release 掉,再對(duì)新的對(duì)象進(jìn)行一次賦值并進(jìn)行一次 retain 操作。

copy:主要用在 NSString 類型,表示復(fù)制內(nèi)容。

系統(tǒng)默認(rèn)是 assign 。retain 是指針的復(fù)制,copy 是內(nèi)容的復(fù)制。

未完,現(xiàn)在要出去一趟,明天繼續(xù)寫(xiě)完ing~~~

// 2017年8月16日 更新 ~~~

5、getter 和 setter 修飾符
assign:用于非指針類型的變量。 用于 基礎(chǔ)數(shù)據(jù)類型(NSInteger和CGFloat) 和 C 數(shù)據(jù)類型(int,float,double,char等),另外 還有 id 也要用assign;
記?。呵懊娌患?* 的就用 assign ;

retain:用于指針變量。 一般用于字符串(NSString ,NSMutableString),數(shù)組(NSMutableArray,NSArray),字典對(duì)象,視圖對(duì)象,控制器對(duì)象等。

重要的事情說(shuō)三遍:
strong 類似于 retain, weak 類似于 assign ;
strong 類似于 retain, weak 類似于 assign;
strong 類似于 retain, weak 類似于 assign;

copy:對(duì) NSString ,NSArray, NSDictionary 等,是因?yàn)樗麄冇謱?duì)應(yīng)的可變類型:NSMutableString,NSMutableArray,NSMutableDictionary。另外,還有block。

以 NSMutableArray 為例,如果用的是 copy 的話,它就相當(dāng)于是 NSArray 了。

@property (nonatomic, copy) NSMutableArray *mArray;等同于

- (void)setMArray:(NSMutableArray *)mArray {
    _mArray = mArray.copy;
}
@property (copy) NSMutableArray *testarr;

// 如果用 copy 的話,就直接崩潰了。
    self.testarr = [[NSMutableArray alloc] initWithCapacity:5];
    [self.testarr addObject:@"a"];
    NSLog(@"testarr>>>%@",self.testarr);

他們之間在賦值的時(shí)候?yàn)榱瞬挥绊懫谄渌淖址闹担瑧?yīng)該用copy重新拷貝一份。

在實(shí)現(xiàn)文件中使用 @synthesize propertyName,編譯器會(huì)先查找這個(gè)屬性名的 setter 和 getter 方法是否被人為實(shí)現(xiàn),如果已經(jīng)實(shí)現(xiàn),就不再實(shí)現(xiàn),如果沒(méi)有,就會(huì)幫我們自動(dòng)生成一個(gè) setter 和 getter 方法,和一個(gè)私有名為_(kāi)propertyName的成員變量。 (注意:系統(tǒng)自動(dòng)創(chuàng)建的都是私有的。Xcode 4.5之后就不用寫(xiě) @synthesize 了)

weak 和 assign 的一些區(qū)別:assign 是指針賦值,不對(duì)其使用計(jì)數(shù)操作的時(shí)候,需要置為 nil,不然會(huì)產(chǎn)生野指針;weak 不會(huì),一旦不用了,就直接釋放了。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請(qǐng)聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時(shí)請(qǐng)結(jié)合常識(shí)與多方信息審慎甄別。
平臺(tái)聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡(jiǎn)書(shū)系信息發(fā)布平臺(tái),僅提供信息存儲(chǔ)服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

友情鏈接更多精彩內(nèi)容