Java設計原則—開閉原則(轉)


原文出自:http://www.cnblogs.com/muzongyan/archive/2010/08/05/1793454.html

 

開閉原則(Open Closed Principle)是Java世界里最基礎的設計原則,它指導我們如何建立一個穩定的、靈活的系統。

 

定義:

一個軟件實體如類、模塊和函數應該對擴展開放,對修改關閉。

Softeware entities like classes,modules and functions should be open for extension but closed for modifications.

 

開閉原則的含義是說一個軟件實體應該通過擴展來實現變化,而不是通過修改已有代碼來實現變化。

軟件實體包括以下幾個部分:

  • 項目或軟件產品中按照一定的邏輯規則划分的模塊
  • 抽象和類
  • 方法

開閉原則是為軟件實體的未來事物而制定的對現行開發設計進行約束的一個原則。

 

注意:開閉原則對擴展開放,對修改關閉,並不意味着不做任何修改,低層模塊的變更,必然要有高層模塊進行耦合,否則就是一個孤立無意義的代碼片段了。

 

變化的類型:

  • 邏輯變化
  • 子模塊變化
  • 可見試圖變化

一個項目的基本路徑應該是這樣的:項目開發、重構、測試、投產、運維,其中的重構可以對原有的設計和代碼進行修改,運維盡量減少對原有代碼修改,保持歷史代碼的純潔性,提高系統的穩定性。

 

開閉原則的重要性:

  • 開閉原則對測試的影響

開閉原則可是保持原有的測試代碼仍然能夠正常運行,我們只需要對擴展的代碼進行測試就可以了。

  • 開閉原則可以提高復用性

在面向對象的設計中,所有的邏輯都是從原子邏輯組合而來的,而不是在一個類中獨立實現一個業務邏輯。只有這樣代碼才可以復用,粒度越小,被復用的可能性就越大。

  • 開閉原則可以提高可維護性
  • 面向對象開發的要求

 

如何使用開閉原則:

  • 抽象約束

第一,通過接口或者抽象類約束擴展,對擴展進行邊界限定,不允許出現在接口或抽象類中不存在的public方法;

第二,參數類型、引用對象盡量使用接口或者抽象類,而不是實現類;

第三,抽象層盡量保持穩定,一旦確定即不允許修改。

  • 元數據(metadata)控制模塊行為

元數據就是用來描述環境和數據的數據,通俗地說就是配置參數,參數可以從文件中獲得,也可以從數據庫中獲得。

Spring容器就是一個典型的元數據控制模塊行為的例子,其中達到極致的就是控制反轉(Inversion of Control)

  • 制定項目章程

在一個團隊中,建立項目章程是非常重要的,因為章程中指定了所有人員都必須遵守的約定,對項目來說,約定優於配置。

  • 封裝變化

對變化的封裝包含兩層含義:

第一,將相同的變化封裝到一個接口或者抽象類中;

第二,將不同的變化封裝到不同的接口或抽象類中,不應該有兩個不同的變化出現在同一個接口或抽象類中。


免責聲明!

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



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