依賴倒置原則例子 依賴倒置和里氏替換的區(qū)別?
依賴倒置和里氏替換的區(qū)別?依賴倒置原則是程序應(yīng)該依賴于抽象接口,而不是具體實(shí)現(xiàn)。簡(jiǎn)言之,需要對(duì)抽象而不是實(shí)現(xiàn)進(jìn)行編程,以減少客戶機(jī)和實(shí)現(xiàn)模塊之間的耦合。Liskov替換原則(LSP)是面向?qū)ο笤O(shè)計(jì)的基
依賴倒置和里氏替換的區(qū)別?
依賴倒置原則是程序應(yīng)該依賴于抽象接口,而不是具體實(shí)現(xiàn)。簡(jiǎn)言之,需要對(duì)抽象而不是實(shí)現(xiàn)進(jìn)行編程,以減少客戶機(jī)和實(shí)現(xiàn)模塊之間的耦合。
Liskov替換原則(LSP)是面向?qū)ο笤O(shè)計(jì)的基本原則之一。Richter的替換原則說(shuō),無(wú)論基類出現(xiàn)在哪里,子類都必須出現(xiàn)。LSP是繼承重用的基石。只有當(dāng)派生類可以替換基類并且不影響軟件單元的功能時(shí),基類才能被重用,派生類才能在基類的基礎(chǔ)上添加新的行為。
Service層和Dao層真的有必要每個(gè)類都加上接口嗎?
這主要取決于您的項(xiàng)目:
例如,如果項(xiàng)目中使用hibernate,以后可能會(huì)切換到mybatis,那么Dao需要使用該接口。這不會(huì)影響上層代碼的更改。
另一個(gè)例子是,項(xiàng)目是一個(gè)單一的應(yīng)用程序。任何代碼修改都需要重新編譯整個(gè)項(xiàng)目,因此不需要接口。如果項(xiàng)目是由模塊編譯和部署的,那么可以使用接口解耦。假設(shè)修改了Dao,只需要重新編譯和部署Dao模塊,而不影響上層模塊。
此外,如果項(xiàng)目團(tuán)隊(duì)中有許多新手,簡(jiǎn)單的代碼結(jié)構(gòu)可能更合適。復(fù)雜項(xiàng)目結(jié)構(gòu)的學(xué)習(xí)成本較高。
如果工程進(jìn)度非常緊迫,我們可以用簡(jiǎn)單粗暴的方式用經(jīng)濟(jì)成本來(lái)說(shuō)明原因。
使用接口的成本是不使用接口的成本(包括后續(xù)維護(hù)成本)。
如果項(xiàng)目變化很大,部署了模塊,項(xiàng)目不急,使用接口的成本比不使用接口的成本低,雖然早期不使用接口似乎更簡(jiǎn)單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢
假設(shè)開(kāi)發(fā)某款軟件1個(gè)程序員10天可以做好,那么找10個(gè)同等水平程序員一起做1天能否做好?
生孩子需要孕婦懷孕10個(gè)月。十個(gè)同級(jí)的女人一個(gè)月能生一個(gè)孩子嗎?