By SmartPtr(http://www.shnenglu.com/SmartPtr/)
粒度:包的內聚性原則
1) 重用發布等價原則(The Release Reuse Equivalency Principle (REP)) * 重用的粒度就是發布的粒度
* 一個可重用的包必須為發布跟蹤系統所管理,使我們在新版本發布后我們還可以繼續使用老版本
* 一個包中的所有類對于同一類用戶來講都應該是可重用的。
2) 共同重用原則(The Common Reuse Principle (CRP))
* 一個包中的所有類應該是共同重用的,如果重用了包中的一個類,就應該重用包中的所有類。
* 一般來說,可重用的類需要與作為該可重用抽象一部份的其它類協作,CRP規定了這些類應該屬于同一個包。
* 放入同一包中的所有類應該是不可分開的,其它包僅僅依賴于其中一部份情況是不可能的(不允許的),否則,我們將要進行不必要的重新驗證與重新發布,并且會白費相當數量的努力。(一個包依賴于另外一個包, 哪怕只是依賴于其中的一個類也不會削弱其依賴關系)
* CRP傾向于把包做的盡可能的小
3) 共同封閉原則(The Common Closure Principle (CCP))
* 包中的所有類對于同一類性質的變化應該是共同封閉的。一個變化若對一個包產生影響,則將對該包中所有類產生影響,而對于其他的包不造成任何影響。
* 這是單一職責原則對于包的重新規定。
* CCP鼓勵我們把可能由于同樣的原因而更改的所有類共同聚集在同一個地方。將變化限制在最小數據的包中。
* CCP傾向于將包做的盡可能的大。
* CCP有益于維護者(包的作者),而REP和CRP有益于重用者(包的使用者)。
穩定性:包的耦合性原則
4) 無環依賴原則(The Acyclic Dependencies Principle (ADP))
* 在包的依賴關系圖中不允許存在環。
* 包的依賴關系圖應該是一個有向無環圖(DAG(Directed Acyclic Grphic))
* 存在環的系統,很難確定包的構建順序,事實上,并不存在恰當的構建順序。
* 打破環的第一個方法:依賴倒置原則,使一個包不再依賴于另一個包,而只是依賴于其抽象接口。
* 打破環的第二個方法: 創建一個新包來包含公共依賴部份。
5) 穩定依賴原則(The Stable Dependencies Principle (SDP))
* 朝著的穩定的方向進行依賴
* 你設計了一個易于更改的包, 其它人只要創建一個對它的依賴就可以使它變的難以更改,這就是軟件的反常特性。通過遵循SDP可以避免這種情況。
* 不穩定性度量:I = Ce / (Ca + Ce). Ca: Afferent Coupling. Ce: Efferent Coupling
* SDP規定一個包的I度量值應該大于它所依賴的包的I的度量值,也就是說,I的度量值應該順著依賴的方向減少。
6) 穩定抽象原則(The Stable Abstractions Principle (SAP))
* 包的抽象程度應該和其穩定程度一致。
* 一個穩定的包同時應該是抽象的,這樣,其穩定性就不會導致其無法擴展。一個不穩定的包應該是具體的,這樣,因為其不穩定性使得其內部的具體代碼易于修改。
* 抽象性度量:A = Na / Nc Na: Number of classes. Nc:Number of abstract classes.
* 創建一個以A為縱軸,I為橫軸的坐標圖,最穩定,最抽象的包位于左上角(0,1)處, 那些最不穩定,最具體的包位于右下角(1,0)處。
posted on 2007-08-26 21:09
SmartPtr 閱讀(979)
評論(2) 編輯 收藏 引用