單一職責(zé)原則(Single Responsibility Principle,SRP):
類的職責(zé)要單一郑趁,不能將太多的職責(zé)放在一個(gè)類中攻走。(高內(nèi)聚、低耦合)
定義:
一個(gè)對(duì)象應(yīng)該只包含單一的職責(zé)繁调,并且該職責(zé)被完整地封裝在一個(gè)類中舅桩。(Every object should have a single responsibility, and that responsibility should be entirely encapsulated by the class.),即又定義有且僅有一個(gè)原因使類變更寨蹋。
原則分析:
1)一個(gè)類(或者大到模塊松蒜,小到方法)承擔(dān)的職責(zé)越多,它被復(fù)用的可能性越小已旧,而且如果一個(gè)類承擔(dān)的職責(zé)過多秸苗,就相當(dāng)于將這些職責(zé)耦合在一起,當(dāng)其中一個(gè)職責(zé)變化時(shí)运褪,可能會(huì)影響其他職責(zé)的運(yùn)作惊楼。?2)類的職責(zé)主要包括兩個(gè)方面:數(shù)據(jù)職責(zé)和行為職責(zé),數(shù)據(jù)職責(zé)通過其屬性來體現(xiàn)吐句,而行為職責(zé)通過其方法來體現(xiàn)胁后。3)單一職責(zé)原則是
實(shí)現(xiàn)高內(nèi)聚、低耦合的
指導(dǎo)方針嗦枢,在很多代碼重構(gòu)手法中都能找到它的存在攀芯,它是最簡單但又最難運(yùn)用的原則,需要設(shè)計(jì)人員發(fā)現(xiàn)類的不同職責(zé)并將其分離文虏,而發(fā)現(xiàn)類的多重職責(zé)需要設(shè)計(jì)人員具有較強(qiáng)的分析設(shè)計(jì)能力和相關(guān)重構(gòu)經(jīng)驗(yàn)侣诺。?
現(xiàn)使用單一職責(zé)原則對(duì)User類進(jìn)行重構(gòu)。
優(yōu)點(diǎn):
1氧秘、降低類的復(fù)雜性年鸳,類的職責(zé)清晰明確。比如數(shù)據(jù)職責(zé)和行為職責(zé)清晰明確丸相。
2搔确、提高類的可讀性和維護(hù)性,
4、變更引起的風(fēng)險(xiǎn)減低膳算,變更是必不可少的座硕,如果接口的單一職責(zé)做得好,一個(gè)接口修改只對(duì)相應(yīng)的類有影響涕蜂,對(duì)其他接口無影響华匾,這對(duì)系統(tǒng)的擴(kuò)展性、維護(hù)性都有非常大的幫助机隙。
注意:
單一職責(zé)原則提出了一個(gè)編寫程序的標(biāo)準(zhǔn)蜘拉,用“職責(zé)”或“變化原因”來衡量接口或類設(shè)計(jì)得是否合理,但是“職責(zé)”和“變化原因”都是沒有具體標(biāo)準(zhǔn)的有鹿,一個(gè)類到底要負(fù)責(zé)那些職責(zé)旭旭?這些職責(zé)怎么細(xì)化?細(xì)化后是否都要有一個(gè)接口或類印颤?這些都需從實(shí)際的情況考慮您机。因項(xiàng)目而異,因環(huán)境而異年局。
建議:
接口一定要做到單一職責(zé),類的設(shè)計(jì)盡量做到只有一個(gè)原因引起變化