Java中23種設計模式介紹和應用場景總結

来源:https://www.cnblogs.com/wa1l-E/archive/2023/01/30/17076304.html
-Advertisement-
Play Games

設計原則 23種設計模式滿足並實現了設計原則中的一個或者多個,從而達到了代碼復用、增加可維護性的目的。 開閉原則(Open+Closed+Principle,OCP) 里氏代換原則(Liskov+Substitution+Principle,LSP) 依賴倒轉原則(Dependency+Invers ...


目錄

設計原則

23種設計模式滿足並實現了設計原則中的一個或者多個,從而達到了代碼復用、增加可維護性的目的。

  • 開閉原則(Open+Closed+Principle,OCP)
  • 里氏代換原則(Liskov+Substitution+Principle,LSP)
  • 依賴倒轉原則(Dependency+Inversion+Principle,DIP)
  • 介面隔離原則(Interface+Segregation+Principle,ISP)
  • 合成/聚合復用原則(Composite%2FAggregate+Reuse+Principle,CARP)
  • 最小知識原則(Principle+of+Least+Knowledge,PLK,也叫迪米特法則)

設計模式

設計模式(Design pattern)代表了最佳的實踐,通常被有經驗的面向對象的軟體開發人員所採用。設計模式是軟體開發人員在軟體開發過程中面臨的一般問題的解決方案。這些解決方案是眾多軟體開發人員經過相當長的一段時間的試驗和錯誤總結出來的。

設計模式是一套被反覆使用的、多數人知曉的、經過分類編目的、代碼設計經驗的總結。使用設計模式是為了重用代碼、讓代碼更容易被他人理解、保證代碼可靠性。 毫無疑問,設計模式於己於他人於系統都是多贏的,設計模式使代碼編製真正工程化,設計模式是軟體工程的基石,如同大廈的一塊塊磚石一樣。項目中合理地運用設計模式可以完美地解決很多問題,每種模式在現實中都有相應的原理來與之對應,每種模式都描述了一個在我們周圍不斷重覆發生的問題,以及該問題的核心解決方案,這也是設計模式能被廣泛應用的原因。

GOF四人幫

在 1994 年,由 Erich Gamma、Richard Helm、Ralph Johnson 和 John Vlissides 四人合著出版了一本名為 Design Patterns - Elements of Reusable Object-Oriented Software(中文譯名:設計模式 - 可復用的面向對象軟體元素) 的書,該書首次提到了軟體開發中設計模式的概念。

四位作者合稱 GOF(四人幫,全拼 Gang of Four)。他們所提出的設計模式主要是基於以下的面向對象設計原則。

  • 對介面編程而不是對實現編程。
  • 優先使用對象組合而不是繼承。

23種設計模式關係

23種設計模式關係圖
image

創建型模式

  • 工廠方法模式
  • 抽象工廠模式
  • 單例模式
  • 建造者模式
  • 原型模式

結構型模式

  • 適配器模式
  • 裝飾器模式
  • 代理模式
  • 外觀模式
  • 橋接模式
  • 組合模式
  • 享元模式

行為型模式

  • 策略模式
  • 模板方法模式
  • 觀察者模式
  • 迭代子模式
  • 責任鏈模式
  • 命令模式
  • 備忘錄模式
  • 狀態模式
  • 訪問者模式
  • 中介者模式
  • 解釋器模式

23種設計模式應用場景


創建型模式應用

  • 工廠方法模式(Factory):工廠創建對象(經典實現:很多框架初始化時都會創建一個工廠對象,用來載入資源)
  • 抽象工廠模式(Abstractfactory):抽象工廠實例創建對象,工廠可修改,靈活度高(經典實現:Struts2插件機制的核心實現就是BeanFactory這個抽象工廠。Spring IOC載入Bean,AOP創建Proxy)
  • 單例模式(Sington):適用於只需要一個對象的情況(經典實現:Tomcat中StringManager的錯誤處理機制)
  • 建造者模式(Builder):一步一步創建一個複雜的對象(經典實現:MyBatis中的SQLSession就是結合了Configure,executor等對象,以此來實現SQLSession的複雜功能)
  • 原型模式(Prototype):複製對象,包括深度複製和淺度複製,深度複製重建引用對象,淺度複製不創建(經典實現:java序列化

結構型模式應用

  • 適配器模式(Adapter):通過實現介面,依賴註入,繼承等方式為不相關的實體建立關係(經典實現:Tomcat新版本連接器Coyote,就是通過為Connector適配建立了ProtocolHandler與Tomcat組件Connector的關聯關係、JDK SET集合)
  • 裝飾器模式(Decorator):創建包裝對象修飾擴展被包裝對象的功能(經典實現:JDK IO家族中BufferedXxx)
  • 代理模式(Proxy):通過添加中間代理的方式限制,過濾,修改被代理類的某些行為(經典實現:Spring AOP核心實現,DataSource中為Connection創建代理對象,改變close方法的行為,使其從開始的關閉連接變成將連接還回連接池)
  • 外觀模式(Facade):通過外觀的包裝,使應用程式只能看到外觀對象,而不會看到具體的細節對象。(經典實現:Tomcat中創建外觀類包裝StandardContext傳給Wrapper,創建外觀類包裝Wrapper以ServletConfiguration的形式傳給Servlet,以此來屏蔽不想讓Servlet可見的那些Tomcat容器參數)
  • 橋接模式(Bridge):將抽象部分與它的實現部分分離,使它們都可以獨立地變化(經典實現:JDBC驅動)
  • 組合模式(Composite):部分與整體,常用於表示樹形結構
  • 享元模式(Flyweight):維護資源集合(經典實現:資料庫連接池,避免重新開啟資料庫鏈接的開銷)

行為型模式應用

  • 策略模式(Strategy):定義多個不同的實現類,這些類實現公共介面,通過調用介面調用不同實例得到不同結果(經典實現:Spring中Bean的定義與註入,Controller,Servcie,repository三層架構中只依賴上一層介面)
  • 模板方法模式(Template):父類定義公共方法,不同子類重寫父類抽象方法,得到不同結果(經典實現:Tomcat生命周期中的init,SpringIOC上層類載入具體子類指定的配置文件、SpringData XXTemplateJDK AQS同步器
  • 觀察者模式(Observer):目標方法被調用,通知所有觀察者(經典實現:Tomcat生命周期事件監聽,Spring BeanPostProcessor實現 )
  • 迭代子模式(Interator):提供一種方法順序訪問一個聚合對象中各個元素, 而又不需暴露該對象的內部表示。(經典實現:JDK Iterator集合迭代器)
  • 責任鏈模式(ChainOfResponsibility):鏈式依賴,依次調用(經典實現:Tomcat Valve
  • 命令模式(Commond):Action定義具體命令,攔截器Invocation回調執行命令(經典實現:Struts2
  • 備忘錄模式(Memento):建立原始對象副本,用於存儲恢複原始對象數據
  • 狀態模式(Stage):通過改變狀態,改變行為(經典實現:切換裝載著不同配置信息的配置文件對象)
  • 訪問者模式(Visitor):結構與操作解耦。靈活的操作,放入固定的結構中執行(經典實現:在SpringAOP的實現過程中首先會有一個ProxyCreator去創建切入點,通知之類的,然後創建一個抽象工廠將這些參數對象傳遞給抽象工廠,抽象工廠調用createAopProxy(this)來創建對象,傳入不同的抽象工廠創建出不同的實體對象)
  • 中介者模式(Mediator):**MVC **框架,其中C(控制器)就是 M(模型)和 V(視圖)的中介者
  • 解釋器模式(Iterpreter):定義分別定義 + - * / 非終結符,組合不同的非終結符定義不同的表達式,維護繁瑣

JAVA中設計模式使用場景總結

設計模式的使用好壞很考驗一個開發人員的編碼能力深度,使用不當則會造成過度設計,增加維護成本。使用錯誤,則會造成設計重構,增加開發時間成本。所以使用設計模式,一定要知其大意並明其深意。
23種設計模式在提出時,就分為了三大類,根據不同的類型應用到不同的業務場景中,使用得當才能更好的應用設計模式。
下麵簡單總結了一下三種設計模式的應用場景

創建型

創建某個或者某些或者某類對象使用,考慮使用創建型設計模式,這些設計模式提供了一種在創建對象的同時隱藏創建邏輯的方式,而不是使用 new 運算符直接實例化對象。這使得程式在判斷針對某個給定實例需要創建哪些對象時更加靈活。

行為型

對象的行為交互(方法調用/回調)功能需要設計,考慮使用行為型設計模式, 這些設計模式特別關註對象之間的通信。

結構型

對象和類之間的關係組合,複雜的設計或許能夠支撐業務的擴展,但維護成本大大增加。簡單的設計或許能夠節約開發成本,但是面對業務的徒增,擴展性太差。考慮類和對象之間的組合關係使用結構型設計模式或許能夠解決問題,這些設計模式關註類和對象的組合。繼承的概念被用來組合介面和定義組合對象獲得新功能的方式。


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

-Advertisement-
Play Games
更多相關文章
  • MySQL具有開源免費,運維簡單,性能好等優點,是在汽車之家使用最多的一種資料庫。資料庫作為應用的後端存儲,承擔著數據持久化存儲的功能,是應用可以正常對外提供服務的關鍵組件,資料庫的高可用非常重要。 相對於成熟的商業資料庫軟體,開源的 MySQL高可用需要使用者自己進行設計和研發,本文介紹汽車... ...
  • Flutter 3.7 發佈,本人對其中後臺 isolate 通道比較感興趣,迫不及待翻譯了下Aaron Clarke文章,第一次翻譯,有不足地方歡迎各位大佬們評論區指正,我將持續更新到本文,謝謝。 原文地址:Introducing background isolate channels | by ...
  • 這裡給大家分享我在網上總結出來的一些知識,希望對大家有所幫助 這樣封裝列表 hooks,一天可以開發 20 個頁面 前言 在做移動端的需求時,我們經常會開發一些列表頁,這些列表頁大多數有著相似的功能:分頁獲取列表、上拉載入、下拉刷新··· 在 Vue 出來 compositionAPI 之前,我們想 ...
  • 下麵是實現移動端 H5 拍照功能的幾種方法: 1、使用 <input type="file">:通過 HTML5 規範中的 <input type="file"> 調用系統攝像頭,並選擇拍攝的照片。但這種方式可能會導致頁面刷新。 實現移動端 H5 拍照功能的代碼: 在 HTML 中創建一個 <inp ...
  • state 有狀態state的組件稱作複雜組件,沒有狀態的組件稱為簡單組件 狀態里存儲數據,數據的改變驅動頁面的展示 <script type="text/babel"> // 創建組件 class Weather extends React.Component { // 構造器調用1次 const ...
  • 1、模塊化的發展過程 var moduleObj = { userName: 'zhangsan', fn: function () { console.log('hello world') } } 使用方式 <html> <head> </head> <body> <script src="a.j ...
  • 一篇文章帶你瞭解設計模式——創建者模式 在之前的文章中我們已經學習了設計模式的基本原則和基本分類 下麵我們來介紹第一種設計模式,創建型模式的主要關註點是怎樣創建對象,它的主要特點是“將對象的創建與使用分離”。 下麵我們將從下麵四個方面講述五種創建者模式: 單例模式 工廠模式 原型模式 建造者模式 單 ...
  • 後端應用分層是什麼,例如:你用Spring MVC開發web程式、項目用三層架構分包,這些都用了分層思想。 MVC模式包含了三部分: 視圖(view):負責界面顯示、處理用戶交互。如:前端應用 控制器(controller):協調視圖層與模型層之間的相互工作。控制器接收視圖層發來的請求,決定用那些模 ...
一周排行
    -Advertisement-
    Play Games
  • Dapr Outbox 是1.12中的功能。 本文只介紹Dapr Outbox 執行流程,Dapr Outbox基本用法請閱讀官方文檔 。本文中appID=order-processor,topic=orders 本文前提知識:熟悉Dapr狀態管理、Dapr發佈訂閱和Outbox 模式。 Outbo ...
  • 引言 在前幾章我們深度講解了單元測試和集成測試的基礎知識,這一章我們來講解一下代碼覆蓋率,代碼覆蓋率是單元測試運行的度量值,覆蓋率通常以百分比表示,用於衡量代碼被測試覆蓋的程度,幫助開發人員評估測試用例的質量和代碼的健壯性。常見的覆蓋率包括語句覆蓋率(Line Coverage)、分支覆蓋率(Bra ...
  • 前言 本文介紹瞭如何使用S7.NET庫實現對西門子PLC DB塊數據的讀寫,記錄了使用電腦模擬,模擬PLC,自至完成測試的詳細流程,並重點介紹了在這個過程中的易錯點,供參考。 用到的軟體: 1.Windows環境下鏈路層網路訪問的行業標準工具(WinPcap_4_1_3.exe)下載鏈接:http ...
  • 從依賴倒置原則(Dependency Inversion Principle, DIP)到控制反轉(Inversion of Control, IoC)再到依賴註入(Dependency Injection, DI)的演進過程,我們可以理解為一種逐步抽象和解耦的設計思想。這種思想在C#等面向對象的編 ...
  • 關於Python中的私有屬性和私有方法 Python對於類的成員沒有嚴格的訪問控制限制,這與其他面相對對象語言有區別。關於私有屬性和私有方法,有如下要點: 1、通常我們約定,兩個下劃線開頭的屬性是私有的(private)。其他為公共的(public); 2、類內部可以訪問私有屬性(方法); 3、類外 ...
  • C++ 訪問說明符 訪問說明符是 C++ 中控制類成員(屬性和方法)可訪問性的關鍵字。它們用於封裝類數據並保護其免受意外修改或濫用。 三種訪問說明符: public:允許從類外部的任何地方訪問成員。 private:僅允許在類內部訪問成員。 protected:允許在類內部及其派生類中訪問成員。 示 ...
  • 寫這個隨筆說一下C++的static_cast和dynamic_cast用在子類與父類的指針轉換時的一些事宜。首先,【static_cast,dynamic_cast】【父類指針,子類指針】,兩兩一組,共有4種組合:用 static_cast 父類轉子類、用 static_cast 子類轉父類、使用 ...
  • /******************************************************************************************************** * * * 設計雙向鏈表的介面 * * * * Copyright (c) 2023-2 ...
  • 相信接觸過spring做開發的小伙伴們一定使用過@ComponentScan註解 @ComponentScan("com.wangm.lifecycle") public class AppConfig { } @ComponentScan指定basePackage,將包下的類按照一定規則註冊成Be ...
  • 操作系統 :CentOS 7.6_x64 opensips版本: 2.4.9 python版本:2.7.5 python作為腳本語言,使用起來很方便,查了下opensips的文檔,支持使用python腳本寫邏輯代碼。今天整理下CentOS7環境下opensips2.4.9的python模塊筆記及使用 ...