在线观看不卡亚洲电影_亚洲妓女99综合网_91青青青亚洲娱乐在线观看_日韩无码高清综合久久

鍍金池/ 問(wèn)答/Java  PHP  網(wǎng)絡(luò)安全/ 開(kāi)放封閉原則(OCP) 和 單一職責(zé)(SRP) 沒(méi)看懂區(qū)別在哪里

開(kāi)放封閉原則(OCP) 和 單一職責(zé)(SRP) 沒(méi)看懂區(qū)別在哪里

網(wǎng)上很多用 計(jì)算器 例子 舉例說(shuō)明這兩個(gè)原則, 但是發(fā)現(xiàn)好像區(qū)別就是 OCP有個(gè)抽象類(lèi), 而SRP沒(méi)有繼承抽象

1.OCP相比較SRP, OCP的例子也都是把一個(gè)個(gè)的功能獨(dú)立出來(lái), 這不就做到了單一職責(zé)么?

2.然后說(shuō)OCP可以做到對(duì)擴(kuò)展開(kāi)放, SRP不也可以做到么, 需要其他運(yùn)算時(shí), 加一個(gè)對(duì)應(yīng)的類(lèi)不就行了, 只不過(guò)相比較OCP, 沒(méi)有去繼承抽象來(lái)約束類(lèi)而已啊, 所以不太理解這里的區(qū)別

3.而所謂 "修改封閉" 啥意思? 沒(méi)太懂, 不知道說(shuō)的是對(duì)哪個(gè)類(lèi)做到了修改封閉, 畢竟即便是OCP, 新擴(kuò)展(增加)一個(gè)運(yùn)算類(lèi)是很容易, 但是增加完了, 不還得在主頁(yè)中中修改(在if else 或 switch case中增加一級(jí)么)

4.很多資料說(shuō) 繼承了抽象, 所以就對(duì)修改封閉 沒(méi)看懂

回答
編輯回答
神經(jīng)質(zhì)

一個(gè)設(shè)計(jì)良好的模塊,拿給別人用,那人需要一些新功能,應(yīng)該怎么用呢,是修改已有模塊代碼?還是用別的手段進(jìn)行擴(kuò)展?開(kāi)閉原則就是你的模塊要是足夠牛逼,就不會(huì)逼著別人改你的源碼╮(╯_╰)╭ 在使用足夠牛逼的模塊時(shí),要通過(guò)擴(kuò)展來(lái)實(shí)現(xiàn)自己的功能而不是改人家代碼。

單一職責(zé)就好理解了,對(duì)于一個(gè)一個(gè)的組件來(lái)說(shuō),多功能是沒(méi)必要的,沙發(fā)是沙發(fā),床是床,沙發(fā)床只能是權(quán)宜之計(jì)。

兩者之間相同的地方就是“如無(wú)必要,勿增實(shí)體”,沒(méi)有必要改代碼就不要改代碼,沒(méi)必要加功能就不要加功能。通過(guò)組件之間的拼接組合實(shí)現(xiàn)整體功能,這樣就能實(shí)現(xiàn)“高內(nèi)聚,低耦合”的理想了。

當(dāng)然這倆原則某種角度來(lái)說(shuō)也是矛盾的,模塊如何才能足夠牛逼?大而全就可以了,然而大而全顯然和單一職責(zé)沖突,所以這里就又有個(gè)權(quán)衡的問(wèn)題,不過(guò)不用擔(dān)心,“權(quán)衡”這種事情是無(wú)處不在的,“選擇比努力重要”說(shuō)的就是權(quán)衡的重要性。

2017年12月22日 03:02
編輯回答
祈歡

這六個(gè)原則在廣義上不是互相沖突的,而且是要求同時(shí)實(shí)現(xiàn)的。

對(duì)于1,OCP所想實(shí)現(xiàn)的能力不影響它同時(shí)是SRP;
對(duì)于2,如你所說(shuō),SRP是通過(guò)增加對(duì)應(yīng)的類(lèi)來(lái)實(shí)現(xiàn)的,也就是說(shuō)增加乘法計(jì)算時(shí)不需要去修改原來(lái)的加法計(jì)算類(lèi),加法計(jì)算類(lèi)對(duì)修改是封閉的,可卻可與通過(guò)繼承計(jì)算基類(lèi)而增加乘法計(jì)算。這就是說(shuō)這個(gè)計(jì)算類(lèi)不只對(duì)修改封閉,還對(duì)拓展開(kāi)放。同理,這不影響每個(gè)子類(lèi)都是單一職則的,而且恰好體現(xiàn)了這些子類(lèi)良好的符合了這兩個(gè)原則。
對(duì)于3,封閉在這里是那個(gè)加法子類(lèi),你不需要擔(dān)心增加乘法后你的加法算法出現(xiàn)問(wèn)題,它是封閉的。

請(qǐng)諸位指正。

2017年1月2日 02:04