ViewController的生命週期分析和使用

做者 shenqiliang 發佈在 2012年3月20日 下午8:11

iOS的SDK中提供不少原生ViewController,大大提升了咱們的開發效率,下面是個人一些經驗。 xcode

1、結構

按結構能夠對iOS的全部ViewController分紅兩類:
一、主要用於展現內容的ViewController,這種ViewController主要用於爲用戶展現內容,並與用戶交互,如UITableViewController,UIViewController。
二、用於控制和顯示其餘ViewController的ViewController。這種ViewController通常都是一個ViewController的容器。如UINavigationController,UITabbarController。它們都有一個屬性:viewControllers。其中UINavigationController表示一種Stack式結構,push一個ViewController或pop一次,所以後一個ViewController通常會依賴前一個ViewController。而UITabbarController表示一個Array結構,各個ViewController是並列的。
第一種ViewController會常常被繼承,用來顯示不一樣的數據給用戶。而第二種不多被繼承,除非你真的須要自定義它。
注:細心的同窗應該能發現,在Xcode中新建一個ViewController時,只能夠選擇繼承自UIViewController和UITableViewController,而它們都是第一種。 app

圖1
函數

2、Controller和View的生命週期

這裏指的View是指Controller的View。它做爲Controler的屬性,生命週期在Controller的生命週期內。就是說你的Controller不能在view釋放前就釋放了。 post

圖2 ViewController生命週期 動畫


當你alloc並init了一個ViewController時,這個ViewController應該是尚未建立view的。ViewController的view是使用了lazyInit方式建立,就是說你調用的view屬性的getter:[self view]。在getter裏會先判斷view是否建立,若是沒有建立,那麼會調用loadView來建立view。loadView完成時會繼續調用viewDidLoad。loadView和viewDidLoad的一個區別就是:loadView時尚未view。而viewDidLoad時view以及建立好了。
當view被添加其餘view中以前時,會調用viewWillAppear,而以後會調用viewDidAppear。
當view從其餘view中移出以前時,會調用viewWillDisAppear,而以後會調用viewDidDisappear。
當view不在使用,並且是disappeared,受到內存警告時,那麼viewController會將view釋放並將其指向nil。 spa

3、代碼組織(如何設計良好的viewcontroller)

ViewController生命週期中有那麼多函數,一個重要問題就是什麼代碼該寫在什麼地方。
一、init裏不要出現建立view的代碼。良好的設計,在init裏應該只有相關數據的初始化,並且這些數據都是比較關鍵的數據。init裏不要調用self.view,不然會致使viewcontroller建立view。(由於view是lazyinit的)。
二、loadView中只初始化view,通常用於建立比較關鍵的view如tableViewController的tabView,UINavigationController的navgationBar,不可調用view的getter(在調super loadView前),最好也不要初始化一些非關鍵的view。若是你是從nib文件中建立的viewController在這裏必定要首先調用super的loadView方法,但建議不要重載這個方法。
三、viewDidLoad 這時候view已經有了,最適合建立一些附加的view和控件了。有一點須要注意的是,viewDidLoad會調用屢次(viewcontroller可能屢次載入view,參見圖2)。
四、viewWillAppear 這個通常在view被添加到superview以前,切換動畫以前調用。在這裏能夠進行一些顯示前的處理。好比鍵盤彈出,一些特殊的過程動畫(好比狀態條和navigationbar顏色)。
五、viewDidAppear 通常用於顯示後,在切換動畫後,若是有須要的操做,能夠在這裏加入相關代碼。
六、viewDidUnload 這時候viewController的view已是nil了。因爲這通常發生在內存警告時,因此在這裏你應該將那些不在顯示的view釋放了。好比你在viewcontroller的view上加了一個label,並且這個label是viewcontroller的屬性,那麼你要把這個屬性設置成nil,以避免佔用沒必要要的內存,而這個label在viewDidLoad時會從新建立。 設計

相關文章
相關標籤/搜索