標籤:style color io os 使用 ar strong 檔案 資料
一、loadView
永遠不要主動調用這個函數。view controller會在view的property被請求並且當前view值為nil時調用這個函數。如果你手動建立view,你應該重載這個函數。如果你用IB建立view並初始化view controller,那就意味著你使用initWithNibName:bundle:方法,這時,你不應該重載loadView函數。
這個方法的預設實現是這樣:先尋找有關可用的nib檔案的資訊,根據這個資訊來載入nib檔案,如果沒有有關nib檔案的資訊,預設實現會建立一個空白的UIView對象,然後讓這個對象成為controller的主view。
所以,重載這個函數時,你也應該這麼做。並把子類的view賦給view屬性(property)(你create的view必須是唯一的執行個體,並且不被其他任何controller共用),而且你重載的這個函數不應該調用super。
如果你要進行進一步初始化你的views,你應該在viewDidLoad函數中去做。在iOS 3.0以及更高版本中,你應該重載viewDidUnload函數來釋放任何對view的引用或者它裡面的內容(子view等等)。
這個網上的資料都說的很不全面,尤其是藍色字部分。
二、viewDidLoad
這個函數在controller載入了相關的views後被調用,而不論這些views儲存在nib檔案裡還是在loadView函數中產生。而多數情況下是做nib檔案的後續工作。
網上資料對這個函數的描述則完全不對。
三、viewDidUnload
這個函數是viewDidLoad的對立函數。在程式記憶體欠缺時,這個函數被controller調用()。由於controller通常儲存著與view(這裡黑體的view指controller的view屬性)相關的對象(一般是view的子view)或者其他運行時建立的對象的引用,所以你必須使用這個函數來放棄這些對象的所有權以便記憶體回收。但不要釋放那些難以重建的資料(不要在這個函數中釋放view)。
通常controller會儲存nib檔案建立的views的引用,但是也可能會儲存著loadView函數建立的對象的引用。最完美的方法是使用合成器方法:
self.myCertainView = nil;
這樣合成器會release這個view,如果你沒有使用property,那麼你得自己顯式釋放這個view。
網上對這個函數的描述含含糊糊,看了等於沒看。
另外:如果controller儲存了其他object和view的引用,你還得在dealloc方法中釋放這些記憶體。對於iOS2.x,你還必須在調用super dealloc方法前將這些引用置為nil。
四、結論
所以流程應該是這樣:
(loadView/nib檔案)來載入view到記憶體 ——>viewDidLoad函數進一步初始化這些view ——>記憶體不足時,調用viewDidUnload函數釋放views
—->當需要使用view時有回到第一步
---------------------------------------------------------------------------------------
補充一點自己碰到的問題:
1.只有在調用到self.view並且view = nil的時候,loadView,viewDidLoad才會被調用到。
2.注意初始化內容的載入順序。如果是手動載入,在loadView的時候加入自己建立的view。ViewDidLoad只對之前的已經載入的view做後續操作,在viewDidLoad之後新建立的內容是可以在記憶體不足時釋放的(這個問題需待測試)。
【iOS】init,loadView,viewDidLoad載入關係