By SmartPtr(http://m.shnenglu.com/SmartPtr/)
面向?qū)ο蟮脑O(shè)計(jì)原則
1 軟件設(shè)計(jì)中存在的問(wèn)題
1)過(guò)于僵硬(Rigidity):很難加入新功能
2)過(guò)于脆弱(Fragility):很難修改
3)復(fù)用率低(Immobility):高層模塊無(wú)法復(fù)用
4)黏度過(guò)高(Viscosity): 破壞原始框架的設(shè)計(jì)
2 好的設(shè)計(jì)的目標(biāo)
1)可擴(kuò)展性(Extensibility):容易添加新的功能而不影響已有模塊
2)靈活性(Flexibility):代碼修改平穩(wěn)地發(fā)生,一處修改不影響另一處
3)可插入性(Pluggability):容易將一個(gè)類(lèi)抽出去,同時(shí)將另一個(gè)有同樣接口地類(lèi)加入進(jìn)來(lái), 而不想象類(lèi)的使用者
3 面向?qū)ο蟮脑O(shè)計(jì)原則
1)“開(kāi)-閉”原則(The Open-Closed Principle):對(duì)可變性地封裝
* Open for extension, closed for modification
* 通過(guò)增加代碼來(lái)變化, 而不是更改現(xiàn)有代碼來(lái)變化
* 封裝可變性, 抽象出抽象體,此抽象體不可更改,但可以通過(guò)派生抽象體來(lái)擴(kuò)展功能。
2)里氏替換原則(The Liskov Substitution Principle):如何進(jìn)行繼承
* 若用類(lèi)S對(duì)象替換類(lèi)T對(duì)象后程序的功能不變,則S是T的子類(lèi)型
* OOD中的Is-A關(guān)系是就行為功能而非內(nèi)在關(guān)系而言, 其繼承概念與通常的數(shù)學(xué)法則和生活常識(shí)是不同范疇的事物, 有不可混淆的區(qū)別
* 在任何父類(lèi)出現(xiàn)的地方都可以用它的子類(lèi)來(lái)替代
3)依賴(lài)倒置原則(Dependence Inversion Principle):針對(duì)接口編程
* 高層模塊不應(yīng)該依賴(lài)于低層模塊。二者都應(yīng)該依賴(lài)于抽象。
* 抽象不應(yīng)該依賴(lài)于細(xì)節(jié),細(xì)節(jié)應(yīng)該依賴(lài)于抽象。
* 類(lèi)之間的耦合關(guān)系:零耦合(Nil Coupling),具體耦合(Concrete Coupling),抽象耦合(Abstract Coupling)
* 從問(wèn)題的具體細(xì)節(jié)中分離出抽象,以抽象方式對(duì)類(lèi)進(jìn)行耦合。
* 但會(huì)導(dǎo)致產(chǎn)生大量的類(lèi)
4)接口隔離原則(Interface Segregation Principle) 恰當(dāng)?shù)貏澐纸巧徒涌?br>* 從一個(gè)客戶(hù)類(lèi)的角度來(lái)講:一個(gè)類(lèi)對(duì)另外一個(gè)類(lèi)的依賴(lài)性應(yīng)當(dāng)是建立在最小的接口上的。使用多個(gè)專(zhuān)門(mén)的接口比使用單一的總結(jié)口要好。
5)合成/聚合復(fù)用原則(Composite/Aggregate Reuse Principle):盡量使用合成/聚合而不使用繼承
* 聚合: 表示擁有或整體與部分的關(guān)系。UML中意為shared(Aggregate), 用空心菱形表示
* 合成:更強(qiáng)的聚合關(guān)系。整體負(fù)責(zé)部分的生命周期,整體和部分是不可分的,部分是不能被共享的。比如孫悟空 ,他的四肢, 和他的武器。悟空和四肢的關(guān)系就是合成,而和武器之間的關(guān)系就是聚合。UML中意為composite, 用實(shí)心菱形表示
* 在一個(gè)新的對(duì)象里面使用一些已有的對(duì)象,使之成為新對(duì)象的一部分;新的對(duì)象通過(guò)向這些對(duì)象的委派達(dá)到復(fù)用這些對(duì)象的目的。
* 繼承優(yōu)點(diǎn):新的實(shí)現(xiàn)較為容易; 比較容易添加到已有系統(tǒng)中
繼承缺點(diǎn):破壞封裝; 很難處理超類(lèi)的變化; 繼承的實(shí)現(xiàn)是靜態(tài)的
* 聚合優(yōu)點(diǎn):支持封裝; 支持包裝; 復(fù)用可以動(dòng)態(tài)進(jìn)行
聚合缺點(diǎn): 不易擴(kuò)展已有系統(tǒng); 需要較多的對(duì)象管理
6)最少知識(shí)法則(Law of Demeter): 不要和陌生人說(shuō)話(huà)
* 只和你直接的朋友們通信,不要和"陌生人"說(shuō)話(huà)
* 一個(gè)對(duì)象應(yīng)當(dāng)對(duì)其他對(duì)象有盡可能少的了解
* 其目的就是降低各個(gè)單元的耦合,提高系統(tǒng)的可維護(hù)性。如Facade, Mediator模式
7) 單一職責(zé)原則(Single Responsibility Principle): 把耦合消滅在萌芽狀態(tài)
* 就一個(gè)類(lèi)而言,應(yīng)該僅有一個(gè)引起它的變化的原因
* 在SRP中, 職責(zé)被定義為“變化的原因”
* 如果一個(gè)類(lèi)承擔(dān)的職責(zé)過(guò)多,導(dǎo)致職責(zé)耦合,一個(gè)職責(zé)的變化可能會(huì)削弱或者抑制這個(gè)類(lèi)完成其它職責(zé)的能力。
* 一個(gè)職責(zé)變化引起該類(lèi)關(guān)于該職責(zé)的接口的變化會(huì)導(dǎo)致所有使用該類(lèi)其它職責(zé)的客戶(hù)重新編譯。
* 一個(gè)職責(zé)可能使用了一些庫(kù),導(dǎo)致這個(gè)類(lèi)的其它職責(zé)的客戶(hù)雖然不需要該功能卻又不得不引入這些庫(kù)。
posted on 2007-08-26 21:08
SmartPtr 閱讀(802)
評(píng)論(1) 編輯 收藏 引用