定義對象之間的一種一對多依賴關(guān)系,使得每當(dāng)一個對象狀態(tài)發(fā)生改變時,其相關(guān)依賴對象皆得到通知并被自動更新号显。觀察者模式的別名包括發(fā)布-訂閱(Publish/Subscribe)模式、模型-視圖(Model/View)模式斑胜、源-監(jiān)聽器(Source/Listener)模式或從屬者(Dependents)模式。
類型
行為型
類圖
參與者
- Subject(目標(biāo)):目標(biāo)又稱為主題,它是指被觀察的對象。在目標(biāo)中定義了一個觀察者集合硝烂,一個觀察目標(biāo)可以接受任意數(shù)量的觀察者來觀察,它提供一系列方法來增加和刪除觀察者對象铜幽,同時它定義了通知方法notify()。目標(biāo)類可以是接口串稀,也可以是抽象類或具體類除抛。
- ConcreteSubject(具體目標(biāo)):具體目標(biāo)是目標(biāo)類的子類,通常它包含有經(jīng)常發(fā)生改變的數(shù)據(jù)母截,當(dāng)它的狀態(tài)發(fā)生改變時到忽,向它的各個觀察者發(fā)出通知;同時它還實(shí)現(xiàn)了在目標(biāo)類中定義的抽象業(yè)務(wù)邏輯方法(如果有的話)清寇。如果無須擴(kuò)展目標(biāo)類喘漏,則具體目標(biāo)類可以省略。
- Observer(觀察者):觀察者將對觀察目標(biāo)的改變做出反應(yīng)华烟,觀察者一般定義為接口翩迈,該接口聲明了更新數(shù)據(jù)的方法update(),因此又稱為抽象觀察者盔夜。
- ConcreteObserver(具體觀察者):在具體觀察者中維護(hù)一個指向具體目標(biāo)對象的引用负饲,它存儲具體觀察者的有關(guān)狀態(tài),這些狀態(tài)需要和具體目標(biāo)的狀態(tài)保持一致喂链;它實(shí)現(xiàn)了在抽象觀察者Observer中定義的update()方法返十。通常在實(shí)現(xiàn)時,可以調(diào)用具體目標(biāo)類的attach()方法將自己添加到目標(biāo)類的集合中或通過detach()方法將自己從目標(biāo)類的集合中刪除椭微。
用法
代碼助記
- 目標(biāo)中定義觀察者列表洞坑,并提供attach/detach方法。
總結(jié)
優(yōu)點(diǎn)
- 觀察者模式可以實(shí)現(xiàn)表示層和數(shù)據(jù)邏輯層的分離蝇率,定義了穩(wěn)定的消息更新傳遞機(jī)制迟杂,并抽象了更新接口刽沾,使得可以有各種各樣不同的表示層充當(dāng)具體觀察者角色。
- 觀察者模式在觀察目標(biāo)和觀察者之間建立一個抽象的耦合逢慌。觀察目標(biāo)只需要維持一個抽象觀察者的集合悠轩,無須了解其具體觀察者。由于觀察目標(biāo)和觀察者沒有緊密地耦合在一起攻泼,因此它們可以屬于不同的抽象化層次火架。
- 觀察者模式支持廣播通信,觀察目標(biāo)會向所有已注冊的觀察者對象發(fā)送通知忙菠,簡化了一對多系統(tǒng)設(shè)計(jì)的難度何鸡。
- 觀察者模式滿足“開閉原則”的要求,增加新的具體觀察者無須修改原有系統(tǒng)代碼牛欢,在具體觀察者與觀察目標(biāo)之間不存在關(guān)聯(lián)關(guān)系的情況下骡男,增加新的觀察目標(biāo)也很方便。
缺點(diǎn)
- 如果一個觀察目標(biāo)對象有很多直接和間接觀察者傍睹,將所有的觀察者都通知到會花費(fèi)很多時間隔盛。
- 如果在觀察者和觀察目標(biāo)之間存在循環(huán)依賴,觀察目標(biāo)會觸發(fā)它們之間進(jìn)行循環(huán)調(diào)用拾稳,可能導(dǎo)致系統(tǒng)崩潰吮炕。
- 觀察者模式?jīng)]有相應(yīng)的機(jī)制讓觀察者知道所觀察的目標(biāo)對象是怎么發(fā)生變化的,而僅僅只是知道觀察目標(biāo)發(fā)生了變化访得。
適用場景
- 一個抽象模型有兩個方面龙亲,其中一個方面依賴于另一個方面,將這兩個方面封裝在獨(dú)立的對象中使它們可以各自獨(dú)立地改變和復(fù)用悍抑。
- 一個對象的改變將導(dǎo)致一個或多個其他對象也發(fā)生改變鳄炉,而并不知道具體有多少對象將發(fā)生改變,也不知道這些對象是誰搜骡。
- 需要在系統(tǒng)中創(chuàng)建一個觸發(fā)鏈拂盯,A對象的行為將影響B(tài)對象,B對象的行為將影響C對象……浆兰,可以使用觀察者模式創(chuàng)建一種鏈?zhǔn)接|發(fā)機(jī)制