原文地址:http://blog.itotem.com.cn/?p=22
- alloc, copy, retain會把引用計數+1
- release會把引用計數-1
- 局部變量如果初始化時不是autorelease的,要及時調用release釋放,并且賦值為nil否則引用仍然存在導致下次無法用nil做是否有值的判斷
- 實例變量要在每次賦值時要先釋放當前引用的對象再賦值,并retain一下保證引用計數為1
- 對于有retain參數的property,直接使用”.”賦值時系統會自動釋放當前引用對象再賦值,并自動retain一下
- dealloc中要對所有實例變量調用release,對于有retain參數的property只需要調用self.theProperty = nil即可,系統會去做釋放
- delegate的property通常設為assign,如果設為retain的話會有循環引用的問題,比如aView.delegate = self時會把self retain一下,在aView的dealloc中會把delegate release,但是由于self的引用永遠不會小于1,所以導致aView和self的dealloc永遠都不會被執行,都永遠駐留內存造成泄露。所以如果要設為retain的話一定要確保不會造成循環引用問題。
- 在UIViewController中的viewDidUnload中要釋放掉局部變量,調用release并設為nil,有時系統收到內存警告時會自動調用這個函數來釋放一些內存空間
- 系統內存警告的回調中要釋放掉內存中的緩存和其他可釋放的東西,以免造成crash
- 使用UITableView時要把cell設置為重用的,并且要確保確實寫得是重用的,有的人寫完的結果相當于還是每次都重建cell,導致效率低下
- 使用UIScrollView時要自己控制釋放掉目前不顯示的內容,尤其是圖片,考慮圖片大小和瀏覽效果可以加載當前顯示頁兩邊的3-5頁內容
- 圖片需要做緩存,尤其是本地文件系統緩存,可以放到Library/Cache目錄中,這個目錄系統有專用的常量來獲取,比如:
這里是一個小例子闡釋前幾條基本原則:
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{ //創建一個局部變量view UIView *view = [[UIView alloc] init]; // 賦值給實例變量theView [theView release]; //先釋放一下當前引用的變量 theView = [view retain]; //給實例變量賦值時需要retain一下 // 如果theView是一個有retain屬性的property self.theView = view; //不需要先釋放,也不需要調用retain,系統會自動做,所以一定不能這樣寫self.view = [[UIView alloc] init];,這樣的話創建的view會被retain兩次,造成泄露,對于這種可以先創建一個局部變量,給self.view賦值后再釋放 [view release]; //要及時釋放局部變量 } - (void)dealloc{ //釋放局部變量 [theView release]; //如果theView是一個有retain屬性的property,也可以這樣寫 self.theView = nil; [super dealloc]; } |