大話設計模式

根據設計模式的參考書 中所提到的,總共有 23 種設計模式。這些模式能夠分爲三大類:建立型模式(Creational Patterns)、結構型模式(Structural Patterns)、行爲型模式(Behavioral Patterns)前端

建立型模式

這些設計模式提供了一種在建立對象的同時隱藏建立邏輯的方式,而不是使用新的運算符直接實例化對象。這使得程序在判斷針對某個給定實例須要建立哪些對象時更加靈活。web

  • 工廠模式(Factory Pattern)
  • 抽象工廠模式(Abstract Factory Pattern)
  • 單例模式(Singleton Pattern)
  • 建造者模式(Builder Pattern)
  • 原型模式(Prototype Pattern)

工廠模式:定義一個建立對象的接口,讓其子類本身決定實例化哪個工廠類,工廠模式使其建立過程延遲到子類進行。算法

抽象工廠模式:提供一個建立一系列相關或相互依賴對象的接口,而無需指定它們具體的類。設計模式

單例模式:保證一個類僅有一個實例,並提供一個訪問它的全局訪問點。數據結構

建造者模式:將一個複雜的構建與其表示相分離,使得一樣的構建過程能夠建立不一樣的表示。網站

原型模式:用原型實例指定建立對象的種類,而且經過拷貝這些原型建立新的對象。ui

結構型模式

這些設計模式關注類和對象的組合。繼承的概念被用來組合接口和定義組合對象得到新功能的方式。spa

  • 適配器模式(Adapter Pattern)
  • 橋接模式(Bridge Pattern)
  • 過濾器模式(Filter、Criteria Pattern)
  • 組合模式(Composite Pattern)
  • 裝飾器模式(Decorator Pattern)
  • 外觀模式(Facade Pattern)
  • 享元模式(Flyweight Pattern)
  • 代理模式(Proxy Pattern)

適配器模式:將一個類的接口轉換成客戶但願的另一個接口。適配器模式使得本來因爲接口不兼容而不能一塊兒工做的那些類能夠一塊兒工做。設計

橋接模式:將抽象部分與實現部分分離,使它們均可以獨立的變化。代理

過濾器模式:這種模式容許開發人員使用不一樣的標準來過濾一組對象,經過邏輯運算以解耦的方式把它們鏈接起來

組合模式:將對象組合成樹形結構以表示"部分-總體"的層次結構。組合模式使得用戶對單個對象和組合對象的使用具備一致性。

裝飾器模式:動態地給一個對象添加一些額外的職責。就增長功能來講,裝飾器模式相比生成子類更爲靈活。

外觀模式:爲子系統中的一組接口提供一個一致的界面,外觀模式定義了一個高層接口,這個接口使得這一子系統更加容易使用。

享元模式:運用共享技術有效地支持大量細粒度的對象。

代理模式:爲其餘對象提供一種代理以控制對這個對象的訪問。

行爲型模式

這些設計模式特別關注對象之間的通訊。

  • 責任鏈模式(Chain of Responsibility Pattern)
  • 命令模式(Command Pattern)
  • 解釋器模式(Interpreter Pattern)
  • 迭代器模式(Iterator Pattern)
  • 中介者模式(Mediator Pattern)
  • 備忘錄模式(Memento Pattern)
  • 觀察者模式(Observer Pattern)
  • 狀態模式(State Pattern)
  • 空對象模式(Null Object Pattern)
  • 策略模式(Strategy Pattern)
  • 模板模式(Template Pattern)
  • 訪問者模式(Visitor Pattern)

責任鏈模式:避免請求發送者與接收者耦合在一塊兒,讓多個對象都有可能接收請求,將這些對象鏈接成一條鏈,而且沿着這條鏈傳遞請求,直到有對象處理它爲止。

命令模式:將一個請求封裝成一個對象,從而使您能夠用不一樣的請求對客戶進行參數化。

解釋器模式:給定一個語言,定義它的文法表示,並定義一個解釋器,這個解釋器使用該標識來解釋語言中的句子。

迭代器模式:提供一種方法順序訪問一個聚合對象中各個元素, 而又無須暴露該對象的內部表示。

中介者模式:用一箇中介對象來封裝一系列的對象交互,中介者使各對象不須要顯式地相互引用,從而使其耦合鬆散,並且能夠獨立地改變它們之間的交互。

備忘錄模式:在不破壞封裝性的前提下,捕獲一個對象的內部狀態,並在該對象以外保存這個狀態。

狀態模式:定義對象間的一種一對多的依賴關係,當一個對象的狀態發生改變時,全部依賴於它的對象都獲得通知並被自動更新。

空對象模式:在空對象模式中,咱們建立一個指定各類要執行的操做的抽象類和擴展該類的實體類,還建立一個未對該類作任何實現的空對象類,該空對象類將無縫地使用在須要檢查空值的地方。

策略模式:定義一系列的算法,把它們一個個封裝起來, 而且使它們可相互替換。

模板模式:定義一個操做中的算法的骨架,而將一些步驟延遲到子類中。模板方法使得子類能夠不改變一個算法的結構便可重定義該算法的某些特定步驟。

訪問者模式:主要將數據結構與數據操做分離。

J2EE 模式

這些設計模式特別關注表示層。這些模式是由 Sun Java Center 鑑定的。

  • MVC 模式(MVC Pattern)
  • 業務表明模式(Business Delegate Pattern)
  • 組合實體模式(Composite Entity Pattern)
  • 數據訪問對象模式(Data Access Object Pattern)
  • 前端控制器模式(Front Controller Pattern)
  • 攔截過濾器模式(Intercepting Filter Pattern)
  • 服務定位器模式(Service Locator Pattern)
  • 傳輸對象模式(Transfer Object Pattern)

MVC模式:

MVC 模式表明 Model-View-Controller(模型-視圖-控制器) 模式。這種模式用於應用程序的分層開發。

  • Model(模型) - 模型表明一個存取數據的對象或 JAVA POJO。它也能夠帶有邏輯,在數據變化時更新控制器。
  • View(視圖) - 視圖表明模型包含的數據的可視化。
  • Controller(控制器) - 控制器做用於模型和視圖上。它控制數據流向模型對象,並在數據變化時更新視圖。它使視圖與模型分離開。

前端控制器模式

前端控制器模式(Front Controller Pattern)是用來提供一個集中的請求處理機制,全部的請求都將由一個單一的處理程序處理。該處理程序能夠作認證/受權/記錄日誌,或者跟蹤請求,而後把請求傳給相應的處理程序。如下是這種設計模式的實體。

  • 前端控制器(Front Controller) - 處理應用程序全部類型請求的單個處理程序,應用程序能夠是基於 web 的應用程序,也能夠是基於桌面的應用程序。
  • 調度器(Dispatcher) - 前端控制器可能使用一個調度器對象來調度請求到相應的具體處理程序。
  • 視圖(View) - 視圖是爲請求而建立的對象。
相關文章
相關標籤/搜索