dip什么意思啊 Service層和Dao層真的有必要每個(gè)類(lèi)都加上接口嗎?
Service層和Dao層真的有必要每個(gè)類(lèi)都加上接口嗎?這主要取決于您的項(xiàng)目:例如,如果項(xiàng)目中使用了hibernate,以后可能會(huì)切換到mybatis,那么Dao需要使用這個(gè)接口。這不會(huì)影響上層代碼的
Service層和Dao層真的有必要每個(gè)類(lèi)都加上接口嗎?
這主要取決于您的項(xiàng)目:
例如,如果項(xiàng)目中使用了hibernate,以后可能會(huì)切換到mybatis,那么Dao需要使用這個(gè)接口。這不會(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)單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢
什么樣的代碼叫好代碼?
好的代碼,滿足兩個(gè)條件:能達(dá)到預(yù)期效果,容易理解。
代碼的不同不在于功能能否實(shí)現(xiàn),而主要在于實(shí)現(xiàn)的質(zhì)量。
有些代碼雖然實(shí)現(xiàn)了效果,但另一個(gè)程序員看不懂,無(wú)法維護(hù),也是壞代碼。
現(xiàn)在在軟件行業(yè),程序員加班是很常見(jiàn)的。疲勞將不可避免地影響代碼的質(zhì)量。
他們大多急于達(dá)到職能要求,完成領(lǐng)導(dǎo)安排的任務(wù),只以完成為目標(biāo)。
這種不考慮長(zhǎng)遠(yuǎn)的工作方式在短時(shí)間內(nèi)實(shí)現(xiàn)了目標(biāo),但從長(zhǎng)遠(yuǎn)來(lái)看是個(gè)大問(wèn)題。
一旦程序員離開(kāi),新來(lái)的人需要很長(zhǎng)時(shí)間才能接手。項(xiàng)目的可擴(kuò)展性和穩(wěn)定性沒(méi)有保證。
尤其是一些外行領(lǐng)導(dǎo)只知道如何為上級(jí)做貢獻(xiàn),不能科學(xué)安排時(shí)間。
功能需求一經(jīng)更改就立即更改,新功能即將出現(xiàn)。因此,工程設(shè)計(jì)不斷調(diào)整,整體建筑穩(wěn)定性受損。
整個(gè)行業(yè)還沒(méi)有意識(shí)到代碼質(zhì)量的重要性,也沒(méi)有對(duì)代碼的敬畏。它只著眼于現(xiàn)在而忽視了長(zhǎng)遠(yuǎn)。
只有行業(yè)人員達(dá)到飽和,淘汰不合格的程序員和產(chǎn)品經(jīng)理,好的代碼才能形成趨勢(shì)。