Posted on 2012-06-09 15:52
eryar 閱讀(1841)
評論(0) 編輯 收藏 引用
Observer Pattern and the Document/View of MFC
觀察者模式與MFC的Document/View
一、觀察者概述
觀察者模式是對象行為模式,用來定義對象間的一種一對多的依賴關(guān)系,當(dāng)一個對象的狀態(tài)發(fā)生改變時,所有依賴于它的對象都得到通知并被自動更新。通常用于將一個系統(tǒng)分割成一系列相互協(xié)作的類有一個常見的副作用:需要維護(hù)相關(guān)對象間的一致性。我們不希望為了維持一致性而使各類緊密耦合,因為這樣降低了它們的可重用性。
例如許多圖形用戶界面工具箱將用戶應(yīng)用界面表示與底下的應(yīng)用數(shù)據(jù)分離。定義應(yīng)用數(shù)據(jù)的類和負(fù)責(zé)界面的類可以各自獨立地復(fù)用。當(dāng)然他們也可以一起工作。觀察者的結(jié)構(gòu)圖如下所示:
Subject
l 目標(biāo)知道它的觀察者??梢杂腥我舛鄠€觀察者觀察同一個目標(biāo);
l 提供注冊和刪除觀察者對象的接口;
Observer
l 為那些在目標(biāo)發(fā)生改變時需要獲得通知的對象定義一個更新接口;
ConcreteSubject
l 將有關(guān)狀態(tài)存入各ConcreteObserver對象;
l 當(dāng)它的狀態(tài)發(fā)生改變時,向它的各個觀察者發(fā)出通知;
ConcreteObserver
l 維護(hù)一個指向ConcreteSubject對象的引用;
l 存儲有關(guān)狀態(tài),這些狀態(tài)應(yīng)與目標(biāo)的狀態(tài)保持一致;
l 實現(xiàn)Observer的更新接口以使自身狀態(tài)與目標(biāo)狀態(tài)保持一致;
二、Document/View Architecture of MFC
類CDocument主要用來存儲數(shù)據(jù);類CView綁定到CDocument并根據(jù)CDocument中的數(shù)據(jù)來顯示出畫面或用來處理與用戶的交互來操作CDocument中的數(shù)據(jù)。Document/View結(jié)構(gòu)的主要好處是一個Document支持多Views,假設(shè)你的程序可以讓用戶以表格的形式看到數(shù)據(jù),也可以以圖形的形式看到數(shù)據(jù),即數(shù)據(jù)有多種表現(xiàn)形式,并且當(dāng)數(shù)據(jù)改變時,表格和圖表形式都同時改變。在MFC中,表格視圖和圖形視圖可以是CView派生出來的不同的類,這些類可以只關(guān)聯(lián)上一個Document對象。Document對象保存數(shù)據(jù),這些視圖訪問Document對象并顯示出從Document對象獲得的數(shù)據(jù)。
當(dāng)用戶更新這些視圖中的一個時,調(diào)用CDocument::UpdateAllViews函數(shù),將會通知這個Document關(guān)聯(lián)的所有視圖,這些視圖將會用CDocument最新的數(shù)據(jù)來更新自己。
如果不把數(shù)據(jù)和視圖分離,這種情況編程將會復(fù)難,特別地當(dāng)視圖自己保存數(shù)據(jù)時。當(dāng)使用Document/View結(jié)構(gòu)后,生活變得容易,這個框架將會為你來做協(xié)調(diào)工作。