iOS之內(nèi)存管理(待續(xù))

內(nèi)存管理是什么?

  • 軟件運(yùn)行時(shí)對內(nèi)存資源進(jìn)行合理分配和使用的技術(shù)前方。其最主要的目的是高效,快速的分配資源,并且在適當(dāng)?shù)臅r(shí)候釋放和回收內(nèi)存資源沪袭。
  • 其本質(zhì)是管理對象的引用計(jì)數(shù),對象的引用計(jì)數(shù)就是標(biāo)記當(dāng)前有多少個(gè)其他對象使用(擁有)這個(gè)對象箱吕。分為自動內(nèi)存管理

引用計(jì)數(shù)

引用計(jì)數(shù)(Reference Count)是一個(gè)簡單而有效的管理對象生命周期的方式。不管是Objective-C、還是Swift丛晌,其內(nèi)存管理方式都是基于引用計(jì)數(shù)的渺绒。

內(nèi)存管理方式

MRC(手動管理iOS5之前)

凡是使用alloc贺喝、init、copy宗兼、nsmutablecopy躏鱼、retain進(jìn)行創(chuàng)建對象的都要使用release或者autorelease進(jìn)行釋放;
規(guī)則:

- 當(dāng)使用alloc/new/copy/retain,創(chuàng)建或引用一個(gè)對象時(shí)會使對象的引用計(jì)數(shù)+1殷绍。
- 當(dāng)不使用對象,會向?qū)ο蟀l(fā)送release或autorelease消息會使對象的引用計(jì)數(shù)-1染苛。
- 當(dāng)一個(gè)對象的引用計(jì)數(shù)為0時(shí),那么它將被銷毀主到,其占用的內(nèi)存被系統(tǒng)回收茶行,OC會自動向其發(fā)送一條dealloc消息(自動調(diào)用dealloc方法)
- 我們此時(shí)可以重寫dealloc方法,在這里釋放相關(guān)資源登钥。一旦某個(gè)對象的引用計(jì)數(shù)為0畔师,那么它就會被系統(tǒng)釋放掉。只要對象的引用計(jì)數(shù)不為0牧牢,它就在內(nèi)存中永遠(yuǎn)不會被釋放看锉, 這樣就會造成內(nèi)存泄露。

ARC(自動管理iOS5之后)

是編譯時(shí)的特性,不需要我們手動retain或者release,系統(tǒng)會在適當(dāng)?shù)臅r(shí)候?yàn)槲覀兲砑酉鄳?yīng)的代碼塔鳍。但是自動管理內(nèi)存需要我們注意循環(huán)引用以防止內(nèi)存泄漏伯铣。
在ARC內(nèi)存管理模式下,其屬性的標(biāo)識符有assign轮纫,strong懂傀,weak,copy蜡感;

- assign在arc中修飾的是基本數(shù)據(jù)類型蹬蚁,mrc中修飾的是delegate防止循環(huán)引用造成內(nèi)存泄漏。
- strong相當(dāng)于mrc中的retain郑兴,使得對象被引用時(shí)引用計(jì)數(shù)加1.
- weak的作用相當(dāng)于assign犀斋,弱引用使用的對象。在arc中delegate的修飾詞是weak情连。作用防止循環(huán)引用造成內(nèi)存泄漏叽粹。
- copy修飾的類型一般是NSString,NSArray,NSDictionary虫几。建立一個(gè)索引計(jì)數(shù)為1的對象锤灿,然后釋放舊對象。
- assign和weak的區(qū)別:
  首先assign修飾的是基本數(shù)據(jù)類型辆脸,簡單賦值不改變引用計(jì)數(shù)但校,weak只可以修飾oc中的對象。其次arc環(huán)境下weak修飾的對象被釋放后指向?qū)ο蟮闹羔槙蛔詣又脼閚il啡氢,而assign修飾的變量可能不會被置為nil状囱,造成野指針會導(dǎo)致程序crash。

iOS內(nèi)存段介紹:

內(nèi)存管理的好處?

iOS內(nèi)存管理機(jī)制的好處就是為了讓開發(fā)人員方便的管理內(nèi)存倘是,減少程序中的內(nèi)存泄漏亭枷,在內(nèi)存管理難度與性能之間找一個(gè)最佳的平衡點(diǎn)。

block的內(nèi)存管理

* 循環(huán)引用
  block一般用copy修飾搀崭,當(dāng)block又引用了對象的其他成員變量時(shí)叨粘,就會對這個(gè)變量本身產(chǎn)生強(qiáng)引用,那么變量本身和它自己的block就形成了循環(huán)引用瘤睹。
__weak typeof (self) weakSelf = self;
  ARC下要生成一個(gè)對自身的弱引用升敲,表示block別再對self對象retain了,避免循環(huán)引用

* block內(nèi)部變量
1.block不能改變局部變量默蚌,要改變時(shí)需加__block修飾
2.block可改變?nèi)肿兞?3.static變量也可在block中修改

內(nèi)存問題的分析解決

僵尸對象和野指針

僵尸對象:內(nèi)存被回收的對象

野指針:指向僵尸對象的指針冻晤,向野指針發(fā)送消息對導(dǎo)致崩潰EXC_BAD_ACCESS

1 在product-scheme-edit scheme-diagnostics中將enable zombie objects勾選上苇羡,下次再出現(xiàn)這樣的錯(cuò)誤就可以準(zhǔn)確定位了绸吸。

2 在Xcode-open developer tool-Instruments打開工具集,選擇Zombies工具可以對已安裝的應(yīng)用進(jìn)行僵尸對象檢測设江。

循環(huán)引用

1)在product-Analyze中使用靜態(tài)分析來檢測代碼中可能存在循環(huán)引用的問題锦茁。

2)在Xcode-open developer tool-Instruments打開工具集,選擇Leaks工具可以對已安裝的應(yīng)用進(jìn)行內(nèi)存泄漏檢測叉存,此工具能檢測靜態(tài)分析不會提示码俩,但是到運(yùn)行時(shí)才會出現(xiàn)的內(nèi)存泄漏問題。

循環(huán)中對象占用內(nèi)存大

循環(huán)內(nèi)產(chǎn)生大量的臨時(shí)對象歼捏,直至循環(huán)結(jié)束才釋放稿存,可能導(dǎo)致內(nèi)存泄漏。

解決方法:在循環(huán)中創(chuàng)建自己的autoReleasePool瞳秽,及時(shí)釋放占用內(nèi)存大的臨時(shí)變量瓣履,減少內(nèi)存占用峰值。

內(nèi)存泄漏

通過Analyze來進(jìn)行靜態(tài)代碼檢查练俐,以發(fā)現(xiàn)在語法上顯而易見的內(nèi)存泄露問題

內(nèi)存泄露是運(yùn)行時(shí)的問題袖迎,這時(shí)可用Instruments中的Allocation和Leaks來不斷重復(fù)操作App,發(fā)現(xiàn)和定位內(nèi)存泄露點(diǎn)

常用的內(nèi)存優(yōu)化方法

圖片讀取:
imageNamed//使用緩存燕锥,適用于頻繁使用的小圖片
imageWithContentOfFile//不使用緩存辜贵,適用于大圖的讀取
文檔讀取
+ (nullable instancetype)dataWithContentsOfFile:(NSString *)path;//
+ (nullable instancetype)dataWithContentsOfFile:(NSString *)path options:(NSDataReadingOptions)readOptionsMask error:(NSError **)errorPtr;//映射文件到虛擬內(nèi)存,大文件時(shí)采用

內(nèi)存警告處理
當(dāng)內(nèi)存不足時(shí)归形,就會收到內(nèi)存警告托慨。在iOS中提供了3中內(nèi)存警告通知方式:

1.在應(yīng)用程序委托中實(shí)現(xiàn)applicationDidReceiveMemoryWarning:方法: 應(yīng)用程序委托對象中接收內(nèi)存警告消息
2.在UIViewController子類中實(shí)現(xiàn)didReceiveMemoryWarning方法:視圖控制器中接收內(nèi)存警告消息
3.注冊UIApplicationDidReceiveMemoryWarningNotification通知:其它類中使用通知接收內(nèi)存警告消息

收到內(nèi)存警告,一般有以下幾種處理方法:
1.盡可能多的釋放資源连霉,尤其是圖片等占用內(nèi)存較多的
2.釋放掉單例對象
3.iOS6之后對于隱藏的viewController直接設(shè)置self.view=nil
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末榴芳,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子跺撼,更是在濱河造成了極大的恐慌窟感,老刑警劉巖,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件歉井,死亡現(xiàn)場離奇詭異柿祈,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)哩至,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進(jìn)店門躏嚎,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事卓鹿⊥嗔颍” “怎么了?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵虚茶,是天一觀的道長。 經(jīng)常有香客問我仇参,道長嘹叫,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任诈乒,我火速辦了婚禮罩扇,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘怕磨。我一直安慰自己喂饥,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布肠鲫。 她就那樣靜靜地躺著员帮,像睡著了一般。 火紅的嫁衣襯著肌膚如雪滩届。 梳的紋絲不亂的頭發(fā)上集侯,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天被啼,我揣著相機(jī)與錄音,去河邊找鬼棠枉。 笑死浓体,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的辈讶。 我是一名探鬼主播命浴,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼贱除!你這毒婦竟也來了生闲?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤月幌,失蹤者是張志新(化名)和其女友劉穎碍讯,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體扯躺,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡捉兴,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了录语。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片倍啥。...
    茶點(diǎn)故事閱讀 38,599評論 1 340
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖澎埠,靈堂內(nèi)的尸體忽然破棺而出虽缕,到底是詐尸還是另有隱情,我是刑警寧澤蒲稳,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布氮趋,位于F島的核電站,受9級特大地震影響弟塞,放射性物質(zhì)發(fā)生泄漏凭峡。R本人自食惡果不足惜拙已,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一决记、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧倍踪,春花似錦系宫、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至缤至,卻和暖如春潮罪,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工嫉到, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留沃暗,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓何恶,卻偏偏與公主長得像孽锥,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子细层,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 43,465評論 2 348

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

  • 內(nèi)存管理 簡述OC中內(nèi)存管理機(jī)制惜辑。與retain配對使用的方法是dealloc還是release,為什么疫赎?需要與a...
    丶逐漸閱讀 1,950評論 1 16
  • iOS內(nèi)存管理 概述 什么是內(nèi)存管理 應(yīng)用程序內(nèi)存管理是在程序運(yùn)行時(shí)分配內(nèi)存(比如創(chuàng)建一個(gè)對象,會增加內(nèi)存占用)與...
    蚊香醬閱讀 5,701評論 8 119
  • 前言 現(xiàn)在iOS開發(fā)已經(jīng)是arc甚至是swift的時(shí)代盛撑,但是內(nèi)存管理仍是一個(gè)重點(diǎn)關(guān)注的問題,如果只知盲目開發(fā)而不知...
    明仔Su閱讀 26,541評論 16 175
  • 內(nèi)存管理的基本范圍和概念. 程序運(yùn)行過程中藥創(chuàng)建大量的對象, 和其他高級語言類似,在ObjC中對象存儲在堆區(qū),程序...
    ValienZh閱讀 876評論 0 2
  • 內(nèi)存管理 ARC處理原理 ARC是Objective-C編譯器的特性捧搞,而不是運(yùn)行時(shí)特性或者垃圾回收機(jī)制撵彻,ARC所做...
    b485c88ab697閱讀 11,188評論 3 47