解析iPhone MVC設計模式要點
接觸iphone的編程,就要從安裝、架構、模式等一些知識來填充自己的編程習慣,那么本文就是講述的這些。
一、概念
MVC架構是一個復雜的架構,其實現也顯得非常復雜。但是,我們已經總結出了很多可靠的設計模式,多種設計模式結合在一起,使MVC架構的實現變得相對簡單易行。Views可以看作一棵樹,顯然可以用Composite Pattern來實現。Views和Models之間的關系可以用Observer Pattern體現。Controller控制Views的顯示,可以用Strategy Pattern實現。Model通常是一個調停者,可采用Mediator Pattern來實現。現在讓我們來了解一下MVC三個部分在J2EE架構中處于什么位置,這樣有助于我們理解MVC架構的實現。MVC與J2EE架構的對應關系是:View處于Web Tier或者說是Client Tier,通常是JSP/Servlet,即頁面顯示部分。Controller也處于Web Tier,通常用Servlet來實現,即頁面顯示的邏輯部分實現。Model處于Middle
二、通信
1、Model和View永遠不能相互通信,只能通過Controller傳遞。
2、Controller可以直接與Model對話(讀寫調用Model),Model通過Notification和KVO機制與Controller間接通信。
3、Controller可以直接與View對話(通過outlet,直接操作View,outlet直接對應到View中的控件),View通過action向Controller報告事件的發生(如用戶Touch我了)。
Controller是View的直接數據源(數據很可能是Controller從Model中取得并經過加工了)。Controller是View的代理(delegate),以同步View與Controller,delegate是一組協議,表示程序將要或者已經處于某種狀態時,來調整View,以對用戶有個交代。例如系統內存不足了,你是不是相應的降低view的質量以節省內存。
注:突然冒出個delegate,讓人不好理解,其實他不對應xcode為我們創建的XXAppDelegate文件,此文件不屬于MVC中的任何一部分,雖然與MVC有聯系。我發現蘋果文檔里說A是B的代理的時候,通常是指A中有B的引用,可以A直接操作B。
三、實作
建立一個BtnClick工程系統,會為我們生成以下文件:
- BtnClickAppDelegate.h
- BtnClickAppDelegate.m
以上兩個文件定義了實現UIApplicationDelegate協議的類BtnClicAppDelegate,UIApplicationDelegate協議是系統預定義的協議,負責監視應用程序的高層行為,處理幾個關鍵系統消息,是應用程序生命周期為我們預留的Hook,每個iphone應用程序必不可少的。iphone應用程序的生命周期:
- BtnClickViewController.h
- BtnClickViewController.m
實現了MVC中的Controller.可以定義一些IBOutlet元素和IBAction方法與View通信。
- @interface BtnClickViewController : UIViewController{
- IBOutlet UILabel* statusText;
- }
- @property (retain,nonatomic) UILabel *statusText;
- (IBAction)buttonPressed:(id)sender;
- @end
View對應那個文件呢? 答案是Resource下的MainWindow.xib和BtnClickViewController.xib。MainWindow.xib文件在在應用程序加載時是會被自動加載的,這其實是在plist文件中配置的。然后MainWindow.xib會加載子視圖BtnClickViewController.xib。
為什么會命名為ViewController,而不是分開命名?可能是因為View和Controller關系太緊密了,view就是Controller的跟班。實際編程時一定要分清MVC各部分的職責。自始至終沒見到Model的面,其實M是可選的,特別是對于簡單的應用。任何與界面無關的,我們添加的自定義類來定義我們應用程序的對象,都屬于Model的范疇。
【編輯推薦】