關(guān)于ARC內(nèi)存管理

前言:這段時間我四處投簡歷面試区丑,然后發(fā)現(xiàn)很多以前的基礎(chǔ)知識有點記不清了,所以趁這段時間趕緊惡補一下有關(guān)方面橱野。

序言:內(nèi)存管理這一模塊對于大多數(shù)的APP來說都是很重要的朽缴,要使app內(nèi)存使用的最大最高效率,還不能讓內(nèi)存泄漏水援,只能從內(nèi)存管理這一塊入手不铆。而一般的iOS內(nèi)存管理有兩種,一種是ARC裹唆,另一種是MRC誓斥,當然這里以ARC的經(jīng)驗為主。

一许帐、ARC是什么劳坑,有什么用

ARC全稱為automatic reference counting。代碼中自動加入了retain跟release成畦,原本需要手動添加內(nèi)存管理引用的計數(shù)可以由編譯器自己完成距芬。對于目前階段來說 ARC比MRC的強大,畢竟是系統(tǒng)自帶的內(nèi)存管理工具循帐,出現(xiàn)紕漏的次數(shù)不在多數(shù)框仔。我的理解是,通過特定的語法拄养,讓編譯器在編譯代碼時离斩,自動生成實例的引用計數(shù)管理部分代碼。

二瘪匿、ARC不是萬能的

ARC只是針對的NSObject的跛梗,他繼承了NSObject,所以他只能管理好NSObject的內(nèi)存釋放棋弥,但是不是絕對沒問題核偿,如果是經(jīng)過強引用循環(huán),還是會造成內(nèi)存泄漏顽染,那要怎么去處理呢漾岳,就是把強引用設(shè)為弱引用就可以了。

ARC管不了CFTypes的對象粉寞,所以當遇到Core Foundation時尼荆,ARC就可以退下了。當然可以用特定的方法仁锯,丙戌要用CFRetain和CFRelease來進行內(nèi)存管理耀找,這里就先不提了。

三、屬性

在這里呢就野芒,就要提一下修飾屬性(@property定義時)

讀寫控制:

readwrite:可讀可寫蓄愁,會生成getter和setter方法。

readonly:只讀狞悲,只會生成getter方法撮抓,不會生成setter方法。

引用方式:

copy:拷貝摇锋,復(fù)制一個對象并創(chuàng)建strong關(guān)聯(lián)丹拯,引用計數(shù)為1,原來對象計數(shù)不變荸恕。

assign:賦值乖酬,不涉及引用計數(shù)的變化,弱引用融求。ARC中對象不能使用assign咬像,但原始類型(BOOL,int生宛,float)仍然可以使用县昂。

retain:持有,對原對象引用計數(shù)加1陷舅,強引用倒彰。ARC中使用strong。

weak:賦值(ARC)莱睁,比assign多了一個功能待讳,對象釋放后把指針設(shè)為nil,避免了野指針缩赛。

修飾變量(修飾不使用@property定義時耙箍,比如函數(shù)內(nèi)的局部變量)

__strong:時缺省的關(guān)鍵詞撰糠,強引用酥馍。

__weak:聲明了一個可以自動置nil的弱引用(ARC中)。

__unsafe_unretained:聲明一個弱引用阅酪,但是不會自動nil化(只有iOS4才會應(yīng)該使用)旨袒。

__autoreleasing:用來修飾一個函數(shù)的參數(shù),這個參數(shù)會在函數(shù)返回的時候被自動釋放(類似autorelease)术辐。

默認的引用計數(shù):

alloc:分配對象砚尽,分配后引用計數(shù)為1。

autorelease:對象引用計數(shù)減1辉词,但如果為0不馬上釋放必孤,等待最近一個pool時釋放。

四、關(guān)于使用ARC的詳解:

1.使用strong還是weak

說到底就是以個歸屬權(quán)的問題敷搪。小心出現(xiàn)循環(huán)引用導(dǎo)致內(nèi)存無法釋放兴想,或者需要引用的對象過早被釋放。大體上:IBOutlet可以為weak赡勘,NSString為copy或strong嫂便,Delegate一般為weak,基礎(chǔ)類型用assign闸与,不過要注意具體使用情況毙替。

2.outlet使用strong還是weak

官方文檔建議一般outlet屬性都推薦使用weak,不是直接作為main view里面一個subview直接顯示出來践樱,而是需要通過實例化創(chuàng)建出來的view厂画,應(yīng)該使用strong(自己創(chuàng)建的要保持引用)。但是要注意使用weak時不要丟失對象的所有權(quán)拷邢,否則應(yīng)該使用strong木羹。

3.delegate主要涉及到互相引用和crash(引用被釋放)問題,為了防止這兩個問題發(fā)生解孙,delegate一般使用weak坑填。

4.修飾block

如果需要block在它被聲明的作用域被銷毀后繼續(xù)使用的話,你就需要做一份拷貝弛姜∑旯澹拷貝會把block移到堆里面。所以廷臼,使用@property時設(shè)置通常如下:

@property(copy,nonatomic)void(^block)(void);

以上是我根據(jù)自己的理解在加上網(wǎng)絡(luò)上各位大神的講解所得出的結(jié)論苍在,若有不妥望提出批評。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末荠商,一起剝皮案震驚了整個濱河市寂恬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌莱没,老刑警劉巖初肉,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異饰躲,居然都是意外死亡牙咏,警方通過查閱死者的電腦和手機,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進店門嘹裂,熙熙樓的掌柜王于貴愁眉苦臉地迎上來妄壶,“玉大人,你說我怎么就攤上這事寄狼《〖模” “怎么了?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長伊磺。 經(jīng)常有香客問我宁舰,道長,這世上最難降的妖魔是什么奢浑? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任蛮艰,我火速辦了婚禮,結(jié)果婚禮上雀彼,老公的妹妹穿的比我還像新娘壤蚜。我一直安慰自己,他們只是感情好徊哑,可當我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布袜刷。 她就那樣靜靜地躺著,像睡著了一般莺丑。 火紅的嫁衣襯著肌膚如雪著蟹。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天梢莽,我揣著相機與錄音萧豆,去河邊找鬼。 笑死昏名,一個胖子當著我的面吹牛涮雷,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播轻局,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼洪鸭,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了仑扑?” 一聲冷哼從身側(cè)響起览爵,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎镇饮,沒想到半個月后蜓竹,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡盒让,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年梅肤,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片邑茄。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖俊啼,靈堂內(nèi)的尸體忽然破棺而出肺缕,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布同木,位于F島的核電站浮梢,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏彤路。R本人自食惡果不足惜秕硝,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望洲尊。 院中可真熱鬧远豺,春花似錦、人聲如沸坞嘀。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽丽涩。三九已至棺滞,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間矢渊,已是汗流浹背继准。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留矮男,地道東北人锰瘸。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓,卻偏偏與公主長得像昂灵,于是被迫代替她去往敵國和親避凝。 傳聞我的和親對象是個殘疾皇子,可洞房花燭夜當晚...
    茶點故事閱讀 44,577評論 2 353

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