IOS 關(guān)于property的詳細(xì)解法

1.格式(@property = ivar + getter + setter)

@property (參數(shù)1,參數(shù)2,...) 類型 名字;?

eg:@property(nonatomic,retain) UIWindow *window;其中參數(shù)主要分為三類:

? 讀寫屬性: (readwrite/readonly/setter = /getter = )

?setter語意:(assign/retain/copy)

? 原?子性: (atomicity/nonatomic)?nullabilityannotations: (nonnull/nullable)

參數(shù)意義:

-readwrite? 產(chǎn)生setter\getter?方法-readonly? 只產(chǎn)生簡單的getter,沒有setter, 默認(rèn)的讀寫屬性? -setter? ? 指定生成setter?法的名字-getter? ? 指定生成getter方法的名字-assign? ? 默認(rèn)類型,setter方法直接賦值,而不進(jìn)?retain操作,適?于基本數(shù)據(jù)類型, 對象類型, 不會(huì)發(fā)?生引用計(jì)數(shù)變化-retainsetter方法對參數(shù)進(jìn)?行release舊值,再retain新值-copysetter方法進(jìn)?行Copy操作,與retain一樣- atomic? ? 保證多線程訪問下的安全,但浪費(fèi)系統(tǒng)資源,原子性控制的默認(rèn)設(shè)置-nonatomic? 禁?多線程,變量保護(hù),提高性能-nonnull? ? 表示對象可以是NULL或nil-nullable? 表?對象不應(yīng)該為空

2.重要屬性對比

<atomic> VS <nonatomic>

1.atomic 是默認(rèn)的屬性,表示對象的操作屬于原子操作,主要是在多線程的環(huán)境下,提供多線程訪問的安全。? 我們知道在多線程的下對對象的訪問都 需要先上鎖訪問后再解鎖,保證不會(huì)同時(shí)有?個(gè)操作針對同?個(gè)對象训措。? 如果編程中不涉及到多線程,不建議使用,因?yàn)槭褂胊tomic?比nonatomic更耗費(fèi)系統(tǒng)資源伪节。

2.nonatomic 表?訪問器的訪問不是原?操作,不支持多線程訪問安全,但 是訪問性能?。

<readwrite> VS <readonly>

1.readwrite 是默認(rèn)的屬性,表?可以對象進(jìn)?讀和寫,自動(dòng)生成setter和getter?法绩鸣。

2.readonly? 表示只允許讀取對象的值,只會(huì)生成對象的getter?法怀大。//以下等價(jià)@property (nonatomic,retain)NSObject *object;@property (nonatomic,retain,readwrite)NSObject *object;

< retain >, < assign > VS < copy >

1.retain 表?示對NSObject和及其?子類對象release舊值,再retain新值,使對象的應(yīng)?計(jì)數(shù)增加?。? 該屬性只能使?用于obejective-c類型對象,不能用于Core Foundation對象全闷。

2.assign 是默認(rèn)屬性,只可以對基本數(shù)據(jù)類型(如CGFloat,NSInteger,Bool,int,代理對象)等使?问潭。? 該方式會(huì)對象直接賦值而不會(huì)進(jìn)行retain操作捺疼。

3.copy? 表?重新建立一個(gè)新的計(jì)數(shù)為1的對象,然后釋放掉舊的值录肯。? 都知道retain是對指針的拷?,copy是對內(nèi)容的拷?溉仑。? eg:NSString 對象 的地址為0x100,其內(nèi)容為“string”? 如果使用copy到另外一個(gè)NSString對 象,則會(huì)?生成另外?個(gè)地址為0x110的對象,只不過內(nèi)容仍然是’string“。? 如果使用retain到另外一個(gè)NSString對象,則該對象的地址仍然為0x100,只不過 該對象的計(jì)數(shù)變?yōu)?/p>

2.retain 是指針拷貝copy是內(nèi)容拷貝//在拷貝之前局服,都會(huì)釋放舊的對象钓瞭。assign:簡單賦值,不更改索引計(jì)數(shù)(Reference Counting)淫奔。copy:建立一個(gè)索引計(jì)數(shù)為1的對象山涡,然后釋放舊對象retain:釋放舊的對象,將舊對象的值賦予輸入對象,再提高輸入對象的輸入對象的索引計(jì)數(shù)為1

//事例說明@property (nonatomic,retain)TestObject *object;@property (nonatomic,copy? )TestObject *object;/********** Getter等效代碼***********///.m中g(shù)etter等效代碼- (TestObject*)object{returnobject;}//.m中g(shù)etter等效代碼- (TestObject*)object{? [objectretain];return? [objectautorelease];//用完立即釋放}/********** Setter等效代碼分析***********/- (void)setObject:(TestObject*)newObject{if(object!=newObject){? ? [objectrelease];object = [newObject copy];

? }

}

< strong > VS < weak >

目的:對象聲明時(shí)需要加?入strong和weak,方便內(nèi)存的自動(dòng)管理鸭丛。? ->strong:強(qiáng)引?用,默認(rèn)的屬性,類似于retain,其實(shí)是一個(gè)相對的概念,就是一個(gè)引用竞穷。? ? 默認(rèn)的所有實(shí)例變量和局部變量都是strong指針。? ? 如果有一個(gè)強(qiáng)引?持有該對象,則該對象就不能被釋放鳞溉。? ->weak:弱引?,類似于assign,弱引用除了不決定對象的存亡外,其他與強(qiáng)引用相同瘾带。? ? 即使一個(gè)對象被持有?數(shù)個(gè)若引用,只要沒有強(qiáng)引用指向他,那麼其還是會(huì)被清除,它不是對象的擁有者。? ? 其值會(huì)在對象被釋放后自動(dòng)設(shè)置為nil熟菲。weak指針主要用于“父-子”關(guān)系,父親擁有?個(gè)?子的strong指針? ? 因此父親是兒子的所有者;但為了阻止所有權(quán)循環(huán),兒?需要使用weak指針指向父親看政。? ? eg:典型例?是delegate模式? ? ViewController通過strong指針(self.view)擁有?個(gè)UITableView的dataSource和delegate都是weak指針

< nonnull > VS < nullable >

1. swift:可以使?!和?來表?一個(gè)對象是optional的還是non- optional,如view?和view!。

2. Objective-C:沒有這一區(qū)分,view即可表示這個(gè)對象是optional,也可表示是non-optional抄罕。說明:這樣就會(huì)造成一個(gè)問題: 在Swift與Objective-C混編時(shí),Swift編譯器并不知道一個(gè)Objective-C對象到 底是optional還是non-optional,因此這種情況下編譯器會(huì)隱式地將Objective- C的對象當(dāng)成是non-optional允蚣。 為了解決這個(gè)問題,蘋果在Xcode6.3引?入了?個(gè)Objective-C的新特性: nullability annotations。這?新特性的核?心是兩個(gè)新的類型注釋:nullable 和nonnull呆贿。->nullable 表?對象可以是NULL或nil->nonnull? 表示對象不應(yīng)該為空? 說明:當(dāng)我們不遵循這一規(guī)則時(shí),編譯器就會(huì)給出警告嚷兔。? 在任何可以使用const關(guān)鍵字的地?都可以使?nullable和nonnull,不過這兩個(gè)關(guān)鍵字僅限于使用在指針類型上。? 在?法的聲明中,我們還可以使用不帶下劃線的nullable和nonnull//建議對象屬性不能為空做入,使用

方式1@property (nonatomic,copy,nonnull)NSArray *items;

//方式1@property (nonatomic,copy? ? ? ? )NSArray *items;//方式2

3.錯(cuò)誤代碼屬性設(shè)置

錯(cuò)誤1:

//錯(cuò)誤寫法@property (nonatomic)NSString *name;@property (nonatomic,assign)NSString *name//等價(jià)//正確寫法@property (nonatomic,copy? )NSString *name;分析:不是基本數(shù)據(jù)類型的對象,所以默認(rèn)的assign修飾符是不行的,由于atomic,readwrite,assign是默認(rèn),以下寫法是可行的://正確寫法@propertyNSInteger maxCount;@property (atomic,assign,readwrite)NSInteger maxCount;//等價(jià)

4.總結(jié)

說明:手動(dòng)實(shí)現(xiàn)getter和setter方法(atomic/nonatomic/retain/assign/copy定義的對象)只是給編譯器的建議,編譯器首先會(huì)到代碼?里?去找谴垫。1.如果定義了相應(yīng)的getter和setter的方法,那么好,?手動(dòng)定義的getter&&setter方法2.如果沒有,編譯器就會(huì)根據(jù)對象自動(dòng)生成相應(yīng)的getter和setter方法

5.????????重點(diǎn)總結(jié)????????

重點(diǎn)!D钢搿!重點(diǎn)H樵酢2式肌!重點(diǎn)r阶骸o拧!询枚!

1.copy? 使用類型 :NSString,block

2.assign使用類型 :delegate,int,float,NSInteger,bool,枚舉违帆,結(jié)構(gòu)體...

3.retain使用類型 :NSArray,NSDate4.strong使用類型 :NSString/block以外的OC對象5.weak? 使用類型 :當(dāng)2個(gè)對象相互引用,一端用strong金蜀,一端用weak刷后;6.readOnly? ? :只讀時(shí)候(即只需要getter方法的時(shí)候);? readWriete? :默認(rèn)屬性(getter&&setter方法)

6.補(bǔ)充

屬性中的修飾詞 - 我的理解 :------------------------------------------------------------------------------

assign ( ARC/MRC )

1.這個(gè)修飾詞是直接賦值的意思 , 整型/浮點(diǎn)型等數(shù)據(jù)類型都用這個(gè)詞修飾 .

2.如果沒有使用 weak strong retain copy 修飾 , 那么默認(rèn)就是使用 assign 了. ( 它們之間是有你沒我的關(guān)系 )

3.當(dāng)然其實(shí)對象也可以用 assign 修飾 , 只是對象的計(jì)數(shù)器不會(huì)+1 . ( 與 strong 的區(qū)別 )

4.如果用來修飾對象屬性 , 那么當(dāng)對象被銷毀后指針是不會(huì)指向 nil 的 . 所以會(huì)出現(xiàn)野指針錯(cuò)誤 .?

weak ( ARC )1.弱指針是針對對象的修飾詞 , 就是說它不能修飾基本數(shù)據(jù)類型 .

2.weak 修飾的對象計(jì)數(shù)器不會(huì)+1 , 也就是直接賦值 .

3.弱引用是為打破循環(huán)引用而生的 .

4.它最被人所喜歡的原因是 它所指向的對象如果被銷毀 , 它會(huì)指向 nil . 而 nil 訪問什么鬼都不會(huì)報(bào)野指針錯(cuò)誤 .

strong ( ARC )

1.直接賦值并且計(jì)數(shù)器 +1 .

2.在 ARC 里替代了 retain 的作用 .

retain ( MRC )1.release 舊對象( 舊對象計(jì)數(shù)器 -1 ) , retain 新對象( 新對象計(jì)數(shù)器 +1 ) , 然后指向新對象 .

2.在set方法里面是這樣的 :? if (_delegate) {? ? ? [_delegate release];? }?

?_delegate = [delegate retain];

copy ( ARC/MRC )1.copy 在 MRC 時(shí)是這樣做的 release 舊對象( 舊對象計(jì)數(shù)器 -1 ) , copy 新對象( 新對象計(jì)數(shù)器 +1 ) , 然后指向新對象 .

1.1在set方法里面是這樣的 :if (_delegate) {[_delegate release];}_delegate = [delegate copy];

2.copy 在 ARC 時(shí)是這么干的 copy 新對象( 新對象計(jì)數(shù)器 +1 ) , 然后指向新對象 .2.1在set方法里面是這樣的 :_delegate = [delegate copy];

3.使用注意 :3.1 修飾的屬性本身要不可變的 . 例如 NSMutableArray 采用 copy 修飾 , 添加元素表面上可以 一到運(yùn)行就崩潰了 , 因?yàn)?copy 過后實(shí)際上成了NSArray了 . ( 隊(duì)友 , 我們不吭你 ) 遵守 NSCopying 協(xié)議的對象使用 .

nonatomic ( ARC/MRC )

1.不對set方法加鎖 .

2.性能好

3.線程不安全

atomic ( ARC/MRC )

1.原子屬性就是對生成的 set 方法加互斥鎖 @synchronized(鎖對象) .@synchronized(self) {? _delegate = delegate;}

2.需要消耗系統(tǒng)資源 .

3.互斥鎖是利用線程同步實(shí)現(xiàn)的 , 意在保證同一時(shí)間只有一個(gè)線程調(diào)用 set 方法 .

4.其實(shí)還有 get 方法 , 要是同時(shí) set 和 get 一起調(diào)用還是會(huì)有問題的 . 所以即使用了 atomic 修飾 還是不夠安全 .

readonly

1.讓 Xcode 只生成get方法 .

2.不想把暴露的屬性被人隨便替換時(shí) , 可以使用 .

readwrite

1.讓 Xcode 生成get/set方法 .

2.不用 readonly 修飾時(shí) , 默認(rèn)就是 readwrite .

------------------------------------------------------------------------------

getter/setter 的自定義方法名 .

1.一般對于 有/無 是/否 等這樣的屬性 , getter 方法名前面加個(gè) is 會(huì)顯得通俗易懂 .

在需要設(shè)值的地方渊抄,我們通過setter設(shè)值方法設(shè)值尝胆;當(dāng)需要取值的時(shí)候,我們采用直接訪問實(shí)例變量的方式护桦。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末含衔,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌贪染,老刑警劉巖缓呛,帶你破解...
    沈念sama閱讀 211,042評(píng)論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異杭隙,居然都是意外死亡哟绊,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 89,996評(píng)論 2 384
  • 文/潘曉璐 我一進(jìn)店門寺渗,熙熙樓的掌柜王于貴愁眉苦臉地迎上來匿情,“玉大人,你說我怎么就攤上這事信殊【娉疲” “怎么了?”我有些...
    開封第一講書人閱讀 156,674評(píng)論 0 345
  • 文/不壞的土叔 我叫張陵涡拘,是天一觀的道長玲躯。 經(jīng)常有香客問我,道長鳄乏,這世上最難降的妖魔是什么跷车? 我笑而不...
    開封第一講書人閱讀 56,340評(píng)論 1 283
  • 正文 為了忘掉前任,我火速辦了婚禮橱野,結(jié)果婚禮上朽缴,老公的妹妹穿的比我還像新娘。我一直安慰自己水援,他們只是感情好密强,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,404評(píng)論 5 384
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著蜗元,像睡著了一般或渤。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上奕扣,一...
    開封第一講書人閱讀 49,749評(píng)論 1 289
  • 那天薪鹦,我揣著相機(jī)與錄音,去河邊找鬼惯豆。 笑死池磁,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的楷兽。 我是一名探鬼主播框仔,決...
    沈念sama閱讀 38,902評(píng)論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼拄养!你這毒婦竟也來了离斩?” 一聲冷哼從身側(cè)響起银舱,我...
    開封第一講書人閱讀 37,662評(píng)論 0 266
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎跛梗,沒想到半個(gè)月后寻馏,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 44,110評(píng)論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡核偿,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,451評(píng)論 2 325
  • 正文 我和宋清朗相戀三年诚欠,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片漾岳。...
    茶點(diǎn)故事閱讀 38,577評(píng)論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡轰绵,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出尼荆,到底是詐尸還是另有隱情左腔,我是刑警寧澤,帶...
    沈念sama閱讀 34,258評(píng)論 4 328
  • 正文 年R本政府宣布捅儒,位于F島的核電站液样,受9級(jí)特大地震影響,放射性物質(zhì)發(fā)生泄漏巧还。R本人自食惡果不足惜鞭莽,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,848評(píng)論 3 312
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望麸祷。 院中可真熱鬧澎怒,春花似錦、人聲如沸阶牍。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,726評(píng)論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽荸恕。三九已至,卻和暖如春死相,著一層夾襖步出監(jiān)牢的瞬間融求,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,952評(píng)論 1 264
  • 我被黑心中介騙來泰國打工算撮, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留生宛,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,271評(píng)論 2 360
  • 正文 我出身青樓肮柜,卻偏偏與公主長得像陷舅,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子审洞,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,452評(píng)論 2 348