深入理解設計模式---系列目錄


一、創建型模式

  1. 深入理解設計模式(一):單例模式(Singleton pattern): 確保一個類只有一個實例, 並提供全局訪問點.

  2. 深入理解設計模式(二):簡單工廠模式(factory method pattern): 實質是由一個工廠類根據傳入的參數,動態決定應該創建哪一個產品類(這些產品類繼承自一個父類或接口)的實例。

  3. 深入理解設計模式(四):工廠方法模式(factory method pattern): 定義了一個創建對象的接口, 但由子類決定要實例化的類是哪一個. 工廠方法讓類把實例化推遲到子類

  4. 深入理解設計模式(五):抽象工廠模式(Abstract factory pattern): 提供一個接口, 用於創建相關或依賴對象的家族, 而不需要指定具體類.

  5. 深入理解設計模式(六):原型模式(prototype pattern): 當創建給定類的實例過程很昂貴或很復雜時, 就使用原形模式.

  6. 深入理解設計模式(七):建造者模式(Builder pattern): 使用生成器模式封裝一個產品的構造過程, 並允許按步驟構造. 將一個復雜對象的構建與它的表示分離, 使得同樣的構建過程可以創建不同的表示

二、行為型模式

  1. 深入理解設計模式(三):策略模式(strategy pattern) : 定義了算法族, 分別封閉起來, 讓它們之間可以互相替換, 此模式讓算法的變化獨立於使用算法的客戶.
  2. 深入理解設計模式(八):觀察者模式(observer pattern) : 在對象之間定義一對多的依賴, 這樣一來, 當一個對象改變狀態, 依賴它的對象都會收到通知, 並自動更新.

  3. 深入理解設計模式(九):模板方法模式(Template pattern) : 在一個方法中定義一個算法的骨架, 而將一些步驟延遲到子類中. 模板方法使得子類可以在不改變算法結構的情況下, 重新定義算法中的某些步驟

  4. 深入理解設計模式(十):命令模式(Command pattern): 將"請求"封閉成對象, 以便使用不同的請求,隊列或者日志來參數化其他對象. 命令模式也支持可撤銷的操作.

  5. 深入理解設計模式(11):狀態模式(State pattern) : 允許對象在內部狀態改變時改變它的行為, 對象看起來好象改了它的類

  6. 深入理解設計模式(12):責任鏈模式(Chain of responsibility pattern): 通過責任鏈模式, 你可以為某個請求創建一個對象鏈. 每個對象依序檢查此請求並對其進行處理或者將它傳給鏈中的下一個對象.

  7. 深入理解設計模式(13):解釋器模式(Interpreter pattern): 使用解釋器模式為語言創建解釋器.

  8. 深入理解設計模式(14):中介者模式(Mediator pattern) : 使用中介者模式來集中相關對象之間復雜的溝通和控制方式.

  9. 深入理解設計模式(15):訪問者模式(visitor pattern) : 當你想要為一個對象的組合增加新的能力, 且封裝並不重要時, 就使用訪問者模式.

  10. 深入理解設計模式(16):備忘錄模式(Memento pattern): 當你需要讓對象返回之前的狀態時(例如, 你的用戶請求"撤銷"), 你使用備忘錄模式.

  11. 深入理解設計模式(17):迭代器模式(iterator pattern): 提供一種方法順序訪問一個聚合對象中的各個元素, 而又不暴露其內部的表示

三、結構型模式

  1. 深入理解設計模式(18):適配器模式(Adapter pattern) : 將一個類的接口, 轉換成客戶期望的另一個接口. 適配器讓原本接口不兼容的類可以合作無間. 對象適配器使用組合, 類適配器使用多重繼承.

  2. 深入理解設計模式(19):裝飾者模式(decorator pattern) : 動態地將責任附加到對象上, 若要擴展功能, 裝飾者提供了比繼承更有彈性的替代方案.

  3. 深入理解設計模式(20):橋接模式(Bridge pattern) : 使用橋接模式通過將實現和抽象放在兩個不同的類層次中而使它們可以獨立改變.

  4. 深入理解設計模式(21):組合模式(composite pattern) : 允許你將對象組合成樹形結構來表現"整體/部分"層次結構. 組合能讓客戶以一致的方式處理個別對象以及對象組合.

  5. 深入理解設計模式(22):享元模式(Flyweight Pattern): 如想讓某個類的一個實例能用來提供許多"虛擬實例", 就使用蠅量模式.

  6. 深入理解設計模式(23):代理模式(Proxy pattern): 為另一個對象提供一個替身或占位符以控制對這個對象的訪問.

  7. 深入理解設計模式(24):外觀模式(facade pattern) : 提供了一個統一的接口, 用來訪問子系統中的一群接口. 外觀定義了一個高層接口, 讓子系統更容易使用.

四、七大設計原則

  深入理解設計模式(序):常用的7大設計原則

  • 單一職責原則(single responsibility principle,SPR):一個類負責一項職責。
  • 開閉原則(Open-Close Principe,OCP):一個軟件實體如類、模塊和函數應該對擴展開放,對修改關閉。
  • 里氏替換原則(Liskov Substitution Principe,LSP):一個軟件實體如果使用的是一個父類的話,那么一定適用於其他子類,二且他察覺不出父類對象和子類對象的區別。
  • 依賴倒置原則(Dependence Inversion Principle):高層模塊不應該依賴低層模塊,二者都應該依賴其抽象;抽象不應該依賴細節;細節應該依賴抽象。即針對接口編程,不要針對實現編程。
  • 接口隔離原則(Interface  Segregation Principle, ISP:建立單一接口,不要建立龐大臃腫的接口,盡量細化接口,接口中的方法盡量少。
  • 迪米特法則(Law of Demeter,LoD):最少知識原則,清掉了類之間的松耦合,降低了系統的耦合度。
  • 組合/聚合復用原則(Composite Reuse Principe,CRP):盡量使用組合和聚合少使用繼承的關系來達到復用的原則

五、總結

  深入理解設計模式(終):總結


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM