開發中,理解高內聚、低耦合


什么是高內聚、低耦合?   

 

1、介紹    

   模塊獨立性指每個模塊只完成系統要求的獨立子功能,並且與其他模塊的聯系最少且接口簡單,兩個定性的度量標准――耦合性和內聚性。     

 

2、耦合性

   (1)定義

      耦合性也稱塊間聯系。指軟件系統結構中各模塊間相互聯系緊密程度的一種度量。模塊之間聯系越緊密,其耦合性就越強,模塊的獨立性則越差。模塊間耦合高低取決於模塊間接口的復雜性、調用的方式及傳遞的信息。

   (2)分類

     耦合性分類(低――高): 無直接耦合;數據耦合;標記耦合;控制耦合;公共耦合;內容耦合;

   (3)詳解

  • 無直接耦合:
  • 數據耦合: 指兩個模塊之間有調用關系,傳遞的是簡單的數據值,相當於高級語言的值傳遞;
  • 標記耦合: 指兩個模塊之間傳遞的是數據結構,如高級語言中的數組名、記錄名、文件名等這些名字即標記,其實傳遞的是這個數據結構的地址;
  • 控制耦合: 指一個模塊調用另一個模塊時,傳遞的是控制變量(如開關、標志等),被調模塊通過該控制變量的值有選擇地執行塊內某一功能;
  • 公共耦合: 指通過一個公共數據環境相互作用的那些模塊間的耦合。公共耦合的復雜程序隨耦合模塊的個數增加而增加。
  • 內容耦合: 這是最高程度的耦合,也是最差的耦合。當一個模塊直接使用另一個模塊的內部數據,或通過非正常入口而轉入另一個模塊內部。

 

3、內聚性

  (1)定義

     內聚性又稱塊內聯系。指模塊的功能強度的度量,即一個模塊內部各個元素彼此結合的緊密程度的度量。若一個模塊內各元素(語名之間、程序段之間)聯系的越緊密,則它的內聚性就越高。

  (2)分類

     內聚性分類(低――高): 偶然內聚;邏輯內聚;時間內聚;通信內聚;順序內聚;功能內聚; 

  (3)詳解

  • 偶然內聚: 指一個模塊內的各處理元素之間沒有任何聯系。
  • 邏輯內聚: 指模塊內執行幾個邏輯上相似的功能,通過參數確定該模塊完成哪一個功能。
  • 時間內聚: 把需要同時執行的動作組合在一起形成的模塊為時間內聚模塊。
  • 通信內聚: 指模塊內所有處理元素都在同一個數據結構上操作(有時稱之為信息內聚),或者指各處理使用相同的輸入數據或者產生相同的輸出數據。
  • 順序內聚: 指一個模塊中各個處理元素都密切相關於同一功能且必須順序執行,前一功能元素輸出就是下一功能元素的輸入。
  • 功能內聚: 這是最強的內聚,指模塊內所有元素共同完成一個功能,缺一不可。與其他模塊的耦合是最弱的。

 

4、要求

       耦合性與內聚性是模塊獨立性的兩個定性標准,將軟件系統划分模塊時,盡量做到高內聚低耦合,提高模塊的獨立性,為設計高質量的軟件結構奠定基礎。

 

5、示例 

      有個例子很容易明白:一個程序有50個函數,這個程序執行得非常好;然而一旦你修改其中一個函數,其他49個函數都需要做修改,這就是高耦合的后果。一旦你理解了它,你編寫概要設計的時候設計類或者模塊自然會考慮到“高內聚,低耦合”。

 

6、原文

      轉載自:http://www.cnblogs.com/robnetcn/archive/2012/04/15/2449008.html

 

 


免責聲明!

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



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