23种设计模式之中介者模式
中介者模式的定義
中介者模式, 當多個類彼此關聯, 會增大耦合性, 這時各個模塊通過中介者進行交流, 每個模塊只負責自己的業務邏輯, 不屬于自己的就丟給中介者, 降低耦合
定義: 用一個中介對象封裝一系列的對象交互, 中介者使各對象不需要顯示的相互作用,從而使其耦合松散,而且可以獨立的改變他們之間的交互.
通用類圖如下:
?
由以下幾部分組成:
抽象中介者代碼:
?
具體中介者代碼:
?
抽象同事類代碼:
?
這個類代碼非常簡單,就是為了建立這個中介而服務的
具體同事類代碼:
?
為什么同事類要使用構造函數注入中介者,而中介者使用 getter/setter 方式注入同事類呢? 這是因為同事類必須擁有中介者, 而中介者卻可以只有部分同事類.
中介者模式的應用
中介者模式的優點:
減少了類間的依賴, 把原有的一對多的以來變成了一對一的依賴, 同事類只依賴中介者,減少了依賴,當然同時也降低了類間的耦合
中介者模式的缺點:
中介者會膨脹得很大,而且邏輯復雜, 原本N個對象直接的相互依賴關系轉換成中介者和同事類的依賴關系, 同事類越多, 中介者的邏輯就越復雜.
中介者模式的使用場景:
中介者模式適用于多個對象之間緊密耦合的情況, 緊密耦合的標準是: 在類圖中出現了蜘蛛網狀結構. 在這種情況下一定要考慮使用中介者模式, 這有利于把蜘蛛網梳理為星型結構,使原本復雜混亂的關系變得清晰簡單
中介者模式的實際應用
中介者模式也叫調停者模式, 什么意思呢? 一個對象要和N多個對象交流, 就像對象間的戰爭, 很混亂. 這時需要加入一個中心, 所有的類都和中心交流, 中心說怎么處理就怎么處理.舉一些常見的例子:
1.機場調度中心.
在每個機場都會看到有一個"XX機場調度中心", 他就是具體的中介者, 用來調度每一架要降落和起飛的飛機.如果沒有機場調度中心, 飛機飛到機場了, 飛行員要先看看有沒有飛機和自己一起降落, 有沒有空跑道燈,這是在難以想象.
2.MVC框架
MVC框架其中的 C(Controller)就是一個中介者, 叫做前端控制器, 它的作用就是把M(Model, 業務邏輯)和V(View, 視圖)隔離開,協調M和V協同工作, 把M運行的結果和V代表的視圖融合成一個前端可以展示的頁面,減少M和V的依賴關系.
3.媒體網關
媒體網關也是一個典型的中介者模式, 比如使用MSN時,張三發消息給李四, 其過程應該是這樣的: 張三發送消息, MSN服務器(中介者)接收到消息, 查找李四,把消息發送到李四, 同時通知張三, 消息已經發送. 在這里, MSN服務器就是一個中轉站, 負責協調兩個客戶端的信息交流.
4.中介服務
現在中介服務非常多, 如租房中介等, 這些也是中介模式的具體體現.
中介者模式很少用到接口或者抽象類, 這與依賴倒置原則是沖突的, 這是為什么呢? 首先, 既然是同事類而不是兄弟類(有相同的血緣), 那就說明這些類之間是協作關系, 完成不同的任務, 處理不同的業務, 所以不能在抽象類或接口中嚴格定義同事類必須具有的方法(從這點也可以看出繼承是高侵入性的).
一個 中介者抽象類一般只有一個實現類, 除非中介者邏輯非常復雜, 代碼量非常大,這時才會出現多個中介者的情況. 對于中介者來說,抽象已經沒有太多的必要.
中介者模式也不要濫用, 可以在如下情況下嘗試使用中介者模式:
總結
以上是生活随笔為你收集整理的23种设计模式之中介者模式的全部內容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: linux 查看指定ip的路由
- 下一篇: 设计模式之创建类模式PK