- 單一職責(zé)原則(SRP):一個(gè)對(duì)象(方法)只做一件事汽馋。
何時(shí)應(yīng)該分離職責(zé)
SRP原則是所有原則中最簡(jiǎn)單也是最難正確運(yùn)用的原則之一。
要明確的是粱年,并不是所有的職責(zé)都應(yīng)該一一分離售滤。
一方面,如果隨著需求的變化台诗,有兩個(gè)職責(zé)總是同時(shí)變化完箩,那就不必分離它們。比如在ajax請(qǐng)求時(shí)候拉队,創(chuàng)建xhr對(duì)象和發(fā)送xhr請(qǐng)求幾乎總是在一起的弊知,那么創(chuàng)建xhr對(duì)象的職責(zé)和發(fā)送xhr請(qǐng)求的職責(zé)就沒(méi)有必要分開。
另一方面粱快,職責(zé)的變化軸線僅當(dāng)它們確定會(huì)發(fā)生變化時(shí)才有意義秩彤,即使兩個(gè)職責(zé)已經(jīng)被耦合在一起,但它們還沒(méi)有發(fā)生改變的征兆事哭,那么也許沒(méi)有必要主動(dòng)分離它們漫雷,在代碼需要重構(gòu)時(shí)再進(jìn)行分離也不遲。
SRP原則的優(yōu)缺點(diǎn)
SRP原則的優(yōu)點(diǎn)是降低了單個(gè)類或者對(duì)象的復(fù)雜度鳍咱,按照職責(zé)把對(duì)象分解成更小的粒度降盹,這有助于代碼的復(fù)用,也有利于進(jìn)行單元測(cè)試流炕。當(dāng)一個(gè)職責(zé)需要變更的時(shí)候澎现,不會(huì)影響到其他的職責(zé)。
SRP的缺點(diǎn)每辟,最明顯的是會(huì)增加編寫代碼的復(fù)雜度剑辫。當(dāng)我們按照職責(zé)把對(duì)象分解成更小的粒度之后,實(shí)際上也增大了這些對(duì)象之間相互聯(lián)系的難度渠欺。
- 最少知識(shí)原則(LKP):在多個(gè)對(duì)象之間引入第三者對(duì)象妹蔽,來(lái)承擔(dān)這些對(duì)象之間的通訊作用。
應(yīng)用:中介者模式挠将,外觀模式胳岂。
- 開放-封閉原則(OCP):軟件實(shí)體(類、模塊舔稀、函數(shù))等應(yīng)該是可以擴(kuò)展的乳丰,但是不可修改。
即當(dāng)需要改變一個(gè)程序的功能或者給這個(gè)程序增加新功能的時(shí)候内贮,可以使用增加代碼的方式产园,但是不允許改動(dòng)程序的源代碼汞斧。