原文地址:http://blog.itotem.com.cn/?p=22
- alloc, copy, retain會(huì)把引用計(jì)數(shù)+1
- release會(huì)把引用計(jì)數(shù)-1
- 局部變量如果初始化時(shí)不是autorelease的,要及時(shí)調(diào)用release釋放,并且賦值為nil否則引用仍然存在導(dǎo)致下次無法用nil做是否有值的判斷
- 實(shí)例變量要在每次賦值時(shí)要先釋放當(dāng)前引用的對象再賦值,并retain一下保證引用計(jì)數(shù)為1
- 對于有retain參數(shù)的property,直接使用”.”賦值時(shí)系統(tǒng)會(huì)自動(dòng)釋放當(dāng)前引用對象再賦值,并自動(dòng)retain一下
- dealloc中要對所有實(shí)例變量調(diào)用release,對于有retain參數(shù)的property只需要調(diào)用self.theProperty = nil即可,系統(tǒng)會(huì)去做釋放
- delegate的property通常設(shè)為assign,如果設(shè)為retain的話會(huì)有循環(huán)引用的問題,比如aView.delegate = self時(shí)會(huì)把self retain一下,在aView的dealloc中會(huì)把delegate release,但是由于self的引用永遠(yuǎn)不會(huì)小于1,所以導(dǎo)致aView和self的dealloc永遠(yuǎn)都不會(huì)被執(zhí)行,都永遠(yuǎn)駐留內(nèi)存造成泄露。所以如果要設(shè)為retain的話一定要確保不會(huì)造成循環(huán)引用問題。
- 在UIViewController中的viewDidUnload中要釋放掉局部變量,調(diào)用release并設(shè)為nil,有時(shí)系統(tǒng)收到內(nèi)存警告時(shí)會(huì)自動(dòng)調(diào)用這個(gè)函數(shù)來釋放一些內(nèi)存空間
- 系統(tǒng)內(nèi)存警告的回調(diào)中要釋放掉內(nèi)存中的緩存和其他可釋放的東西,以免造成crash
- 使用UITableView時(shí)要把cell設(shè)置為重用的,并且要確保確實(shí)寫得是重用的,有的人寫完的結(jié)果相當(dāng)于還是每次都重建cell,導(dǎo)致效率低下
- 使用UIScrollView時(shí)要自己控制釋放掉目前不顯示的內(nèi)容,尤其是圖片,考慮圖片大小和瀏覽效果可以加載當(dāng)前顯示頁兩邊的3-5頁內(nèi)容
- 圖片需要做緩存,尤其是本地文件系統(tǒng)緩存,可以放到Library/Cache目錄中,這個(gè)目錄系統(tǒng)有專用的常量來獲取,比如:
這里是一個(gè)小例子闡釋前幾條基本原則:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 | - (void)aFunction{ //創(chuàng)建一個(gè)局部變量view UIView *view = [[UIView alloc] init]; // 賦值給實(shí)例變量theView [theView release]; //先釋放一下當(dāng)前引用的變量 theView = [view retain]; //給實(shí)例變量賦值時(shí)需要retain一下 // 如果theView是一個(gè)有retain屬性的property self.theView = view; //不需要先釋放,也不需要調(diào)用retain,系統(tǒng)會(huì)自動(dòng)做,所以一定不能這樣寫self.view = [[UIView alloc] init];,這樣的話創(chuàng)建的view會(huì)被retain兩次,造成泄露,對于這種可以先創(chuàng)建一個(gè)局部變量,給self.view賦值后再釋放 [view release]; //要及時(shí)釋放局部變量 } - (void)dealloc{ //釋放局部變量 [theView release]; //如果theView是一個(gè)有retain屬性的property,也可以這樣寫 self.theView = nil; [super dealloc]; } |