(轉載)由init、loadView、viewDidLoad、viewDidUnload、de...

init方法緩存

在init方法中實例化必要的對象(聽從LazyLoad思想)對象

‍init方法中初始化ViewController自己索引

 loadView方法內存

當view須要被展現而它倒是nil時,viewController會調用該方法。不要直接調用該方法。it

若是手工維護views,必須重載重寫該方法內存管理

若是使用IB維護views,必須不能重載重寫該方法變量

loadView和IB構建view請求

你在控制器中實現了loadView方法,那麼你可能會在應用運行的某個時候被內存管理控制調用。 若是設備內存不足的時候, view 控制器會收到didReceiveMemoryWarning的消息。 默認的實現是檢查當前控制器的view是否在使用。 若是它的view不在當前正在使用的view hierarchy裏面,且你的控制器實現了loadView方法,那麼這個view將被release, loadView方法將被再次調用來建立一個新的view。方法

 

viewDidLoad方法數據

viewDidLoad 此方法只有當view從nib文件初始化的時候才被調用。

重載重寫該方法以進一步定製view

在iPhone OS 3.0及以後的版本中,還應該重載重寫viewDidUnload來釋放對view的任何索引

viewDidLoad後調用數據Model

viewDidUnload方法‍

當系統內存吃緊的時候會調用該方法(注:viewController沒有被dealloc)

內存吃緊時,在iPhone OS 3.0以前didReceiveMemoryWarning是釋放無用內存的惟一方式,可是OS 3.0及之後viewDidUnload方法是更好的方式

在該方法中將全部IBOutlet(不管是property仍是實例變量)置爲nil(系統release view時已經將其release掉了)

在該方法中釋放其餘與view有關的對象、其餘在運行時建立(但非系統必須)的對象、在viewDidLoad中被建立的對象、緩存數據等 release對象後,將對象置爲nil(IBOutlet只須要將其置爲nil,系統release view時已經將其release掉了)

通常認爲viewDidUnload是viewDidLoad的鏡像,由於當view被從新請求時,viewDidLoad還會從新被執行

viewDidUnload中被release的對象必須是很容易被從新建立的對象(好比在viewDidLoad或其餘方法中建立的對象),不要release用戶數據或其餘很難被從新建立的對象

dealloc方法

viewDidUnload和dealloc方法沒有關聯,dealloc仍是繼續作它該作的事情

相關文章
相關標籤/搜索