23種設計模式之門面模式

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

門面模式的定義 定義: 要求一個子系統的外部與其內部的通信必須通過一個統一的對象進行. 門面模式提供一個高層次的介面, 使得子系統更易於使用. 通俗的說, 就是設計一個類,專門用於對外服務的, 門面對象是外界訪問子系統內部的唯一通道 其類圖如下: 其中兩個角色如下: 子系統代碼如下: 門面對象代碼: ...


門面模式的定義

定義: 要求一個子系統的外部與其內部的通信必須通過一個統一的對象進行. 門面模式提供一個高層次的介面, 使得子系統更易於使用.

通俗的說, 就是設計一個類,專門用於對外服務的, 門面對象是外界訪問子系統內部的唯一通道

其類圖如下:

23種設計模式之門面模式

 

其中兩個角色如下:

  1. Facade 門面角色: 客戶端可以調用這個角色的方法. 此角色知曉子系統的所有功能和責任. 一般情況下, 本角色會將所有從客戶端發來的請求委派到相應的子系統去, 也就是說該角色沒有實際的業務邏輯, 只是一個委托類
  2. Subsystem 子系統角色: 可以同時有一個或多個子系統. 每一個子系統都不是一個單獨的類, 而是一個類的集合.子系統並不知道門面的存在. 對於子系統而言, 門面僅僅是另外一個客戶端而已

子系統代碼如下:

23種設計模式之門面模式

 

門面對象代碼:

23種設計模式之門面模式

 

門面模式的應用

門面模式的優點:

  1. 減少系統的相互依賴. 如果不使用門面模式, 外界訪問直接深入到子系統內部, 相互之間是一種強耦合關係, 這樣的強依賴是系統設計所不能接受的. 門面模式的出項很好的解決了這個問題, 所有的依賴都是對門面對象的依賴, 與子系統無關.
  2. 提高了靈活性. 依賴減少了, 靈活性自然提高了.
  3. 提高安全性. 想讓你訪問子系統的哪些業務就開通那些邏輯, 不在門面上開通的方法, 休想訪問到

門面模式的缺點:

門面模式最大的缺點就是不符合開閉原則, 對修改關閉, 對擴展開放. 一旦在系統投產後發現有一個小錯誤, 怎麼解決? 完全最從開閉原則,根本沒辦法解決. 唯一能做的一件事就是修改門面對象的代碼, 這個風向相當大.

門面模式的使用場景:

  1. 為一個複雜的模塊或子系統提供一個供外界訪問的介面
  2. 子系統相對獨立--外界對子系統的訪問只要黑箱操作即可.
  3. 預防低水平人員帶來的風險擴散.

門面模式的註意事項

1.一個子系統可以有多個門面

  1. 門面已經龐大到不能忍受的重讀. 當一個門面對象過於龐大, 雖然都是非常簡單的委托操作, 也建議拆分成多個門面,否則會給以後的維護和擴展帶來不必要的麻煩. 按照功能拆分是一個非常好的原則, 比如一個資料庫操作的門面可以拆分為增刪改查等
  2. 子系統可以提供不同訪問路徑, 當有兩個不同的高層模塊來訪問子系統, 模塊二屬於受限訪問對象, 只能訪問methodB 方法, 如何處理呢?
23種設計模式之門面模式

 

增加的門面非常簡單, 委托給已經存在的門面對象來處理. 這樣可以儘量保持相同的代碼只編寫一遍, 避免以後到處修改相似代碼的悲劇.

2.門面不參與子系統內的業務邏輯

門面對象中不要出現具體的業務邏輯代碼, 否則就會產生一個倒依賴的問題, 在門面模式中, 門面角色應該是穩定的, 它不應該經常變化, 一個系統一旦投入運行他就不應該被改變, 它是一個系統對外的介面, 變來變去還怎麼保證其他模塊的穩定運行呢?

如果一定要出現業務處理, 應該建立一個封裝類, 封裝完畢後提供給門面對象使用.


門面模式是一個很好的封裝方法, 一個子系統比較複雜時, 比如演算法或者業務比較複雜, 就可以封裝出一個或多個門面出來, 項目的介面簡單, 而且擴展性非常好. 還有, 對於一個較大的項目, 為了避免人員帶來的風險, 也可以使用門面模式.


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

-Advertisement-
Play Games
更多相關文章
  • 顧名思義 用箭頭 “ => ” 定義函數,如果箭頭函數的代碼塊部分有多條語句,就要使用大括弧將它們括起來,並且使用return返回。由於花括弧{ }被解釋為代碼塊,所以如果箭頭函數直接返回一個對象,必須在對象外面加上花括弧,否則會報錯。 ...
  • forEach函數用得平時用得比較多,但是從來沒想到forEach函數還有第二個參數。 這裡是菜鳥教程對forEach函數的詳細說明:forEach的詳細說明。 如上圖,forEach函數有第二個參數 thisValue。 簡單點來說,就是我們可以直接使用第二個參數來指定函數里的this的值,而不需 ...
  • (1)node Node.js 是一個基於 Chrome V8 引擎的 JavaScript 運行環境。 Node與javaScript的區別在於,javaScript的頂層對象是window,而node是global 模塊:在node中,文件和模塊是一一對應的,也就是一個文件就是一個模塊;每個模塊 ...
  • 數組的增加方法 1.push()方法向數組中末尾添加一個元素,原數組改變 2.unshit()方法向數組中開始元素添加一個元素,原數組改變 3.splice()方法 ary.splice(n,m,x) 從索引n開始刪除m個元素,把新增的元素X放在索引n的前面,把刪除的元素當成一個新數組返回,原有數組 ...
  • 0、URL格式 protocol :// hostname[:port] / path / [;parameters][?query]#fragment [;parameters]沒見過 這裡就不做相關匹配了 1、代碼及運行結果 'use strict'; { // URL地址匹配格式: proto ...
  • 本文由雲+社區發表 相信大家在平常的 JavaScript 開發中,都有遇到過浮點數運算精度誤差的問題,比如 。在 JavaScript 中,所有的數字包括整數和小數都是用 類型來表示的。本文通過介紹 的二進位存儲標準來理解浮點數運算精度問題,和理解 對象的 等屬性值是如何取值的,最後介紹了一些常用 ...
  • "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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...