23種設計模式之中介者模式

来源:https://www.cnblogs.com/hujingnb/archive/2018/12/26/10171558.html
-Advertisement-
Play Games

中介者模式的定義 中介者模式, 當多個類彼此關聯, 會增大耦合性, 這時各個模塊通過中介者進行交流, 每個模塊只負責自己的業務邏輯, 不屬於自己的就丟給中介者, 降低耦合 定義: 用一個中介對象封裝一系列的對象交互, 中介者使各對象不需要顯示的相互作用,從而使其耦合鬆散,而且可以獨立的改變他們之間的 ...


中介者模式的定義

中介者模式, 當多個類彼此關聯, 會增大耦合性, 這時各個模塊通過中介者進行交流, 每個模塊只負責自己的業務邏輯, 不屬於自己的就丟給中介者, 降低耦合

定義: 用一個中介對象封裝一系列的對象交互, 中介者使各對象不需要顯示的相互作用,從而使其耦合鬆散,而且可以獨立的改變他們之間的交互.

通用類圖如下:

23種設計模式之中介者模式

 

由以下幾部分組成:

  1. AbstractMediator 抽象中介者: 抽象中介者角色定義統一的介面, 用於各同事角色之間的通信.
  2. Mediator 具體中介者: 具體中介者角色通過協調各同事角色實現協作行為,因此它必須依賴各個同事角色
  3. AbstractColleague 抽象同事角色: 每一個同事角色都知道中介者角色, 而且與其他同事通信的時候, 一定要通過中介者角色協作.每個同事類的行為分為兩種: 一種是同事本身的行為,叫做自發行為,與其他的同事類或中介者沒有任何的依賴; 第二種是必須依賴中介者才能完成的行為, 叫做依賴方法

抽象中介者代碼:

23種設計模式之中介者模式

 

具體中介者代碼:

23種設計模式之中介者模式

 

抽象同事類代碼:

23種設計模式之中介者模式

 

這個類代碼非常簡單,就是為了建立這個中介而服務的

具體同事類代碼:

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.中介服務

現在中介服務非常多, 如租房中介等, 這些也是中介模式的具體體現.


中介者模式很少用到介面或者抽象類, 這與依賴倒置原則是衝突的, 這是為什麼呢? 首先, 既然是同事類而不是兄弟類(有相同的血緣), 那就說明這些類之間是協作關係, 完成不同的任務, 處理不同的業務, 所以不能在抽象類或介面中嚴格定義同事類必須具有的方法(從這點也可以看出繼承是高侵入性的).

一個 中介者抽象類一般只有一個實現類, 除非中介者邏輯非常複雜, 代碼量非常大,這時才會出現多個中介者的情況. 對於中介者來說,抽象已經沒有太多的必要.

中介者模式也不要濫用, 可以在如下情況下嘗試使用中介者模式:

  1. N個對象之間產生了相互的依賴關係(N>2)
  2. 多個對象有依賴關係, 但是依賴的行為尚不確定或者有發生改變的可能, 在這種 情況下一般建議採用中介者模式,降低變更引起的風險擴散
  3. 產品開發. 一個明顯的例子就是MVC框架, 把中介者模式應用到產品中, 可以提升產品的性能和擴展性,但是對於項目開發就未必, 因為項目是以交付投產為目標,而產品是以穩定、高效、擴展為宗旨.

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • "React 入門學習筆記整理(一)——搭建環境" "React 入門學習筆記整理(二)—— JSX簡介與語法 " "React 入門學習筆記整理(三)—— 組件 " "React 入門學習筆記整理(四)—— 事件 " "React 入門學習筆記整理(五)—— state " "React 入門學習 ...
  • 迭代器模式的定義 定義: 它提供一種方法訪問一個容器對象中各個元素, 而又不需暴露該對象的內部細節 其類圖如下: 其中角色: 其代碼實現如下: 抽象迭代器: 具體迭代器: 抽象容器: 具體容器: 場景類: 迭代器模式的應用 其實, 現在基本上所有的高級語言都實現了迭代器, 基本上跟很少有項目再獨立寫 ...
  • 門面模式的定義 定義: 要求一個子系統的外部與其內部的通信必須通過一個統一的對象進行. 門面模式提供一個高層次的介面, 使得子系統更易於使用. 通俗的說, 就是設計一個類,專門用於對外服務的, 門面對象是外界訪問子系統內部的唯一通道 其類圖如下: 其中兩個角色如下: 子系統代碼如下: 門面對象代碼: ...
  • 通過創建現有對象的對象,以便向外界通過訪問介面,這種模式我們稱之為代理模式 介紹 代理模式屬於結構型模式,通過在對象與對象之間添加一個代理中間層來到達對目標對象的間接訪問。 類圖描述 由上圖可知,我們通過定義一個基本介面來約束業務行為,然後定義具體的業務實現該介面,最後通過定義一個代理類來協調上層和 ...
  • 策略模式的定義 定義: 定義一組演算法, 將每個演算法都封裝起來, 並且使它們之間可以互換 通俗的說, 就是對一個介面下的一組演算法進行封裝 其類圖如下: 其中三個角色說明: 策略模式的重點就是封裝角色, 它借用了代理模式的思路, 差別就是策略模式的封裝角色和被封裝的策略類不用是同一個介面, 如果是同一個 ...
  • 裝飾模式的定義 定義: 動態的給一個對象添加一些額外的職責. 就增加功能來說, 裝飾模式相比生成子類更為靈活. 通俗的說, 就是對一個類或方法進行包裝 裝飾模式的通用類圖: 類圖中的四個角色說明如下: 具體實現代碼如下: 抽象裝飾者代碼: 具體裝飾者代碼: 場景類: 裝飾模式應用 裝飾模式的優點: ...
  • 命令模式的定義 定義: 將一個請求封裝成一個對象, 從而讓你使用不同的請求將客戶端參數化, 對請求排隊或者記錄請求日誌, 可以提供命令的撤銷和恢復功能 通俗的說, 就是當有不同的請求時, 將每一種請求都封裝成一個對象, 不同的請求調用不同的執行者來執行 命令模式的通用類圖如下: 其中各部分如下: 接 ...
  • 責任鏈模式的定義 定義: 使多個對象都有機會處理請求, 從而避免了請求的發送者和接受者之間的耦合關係. 將這些對象連成一條鏈, 並沿著這條鏈傳遞該請求,直到有對象處理它為止 通俗的講, 就是將對請求的處理組成一條鏈, 當請求來時, 在鏈中依次傳遞, 知道找到能夠處理此請求的對象 其通用類圖如下: 責 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...