dao接口和實現(xiàn)類 Service層和Dao層真的有必要每個類都加上接口嗎?
Service層和Dao層真的有必要每個類都加上接口嗎?這主要取決于您的項目:例如,如果項目中使用了hibernate,以后可能會切換到mybatis,那么Dao需要使用這個接口。這不會影響上層代碼的
Service層和Dao層真的有必要每個類都加上接口嗎?
這主要取決于您的項目:
例如,如果項目中使用了hibernate,以后可能會切換到mybatis,那么Dao需要使用這個接口。這不會影響上層代碼的更改。
另一個例子是,項目是一個單一的應(yīng)用程序。任何代碼修改都需要重新編譯整個項目,因此不需要接口。如果項目是由模塊編譯和部署的,那么可以使用接口解耦。假設(shè)修改了Dao,只需要重新編譯和部署Dao模塊,而不影響上層模塊。
此外,如果項目團隊中有許多新手,簡單的代碼結(jié)構(gòu)可能更合適。復(fù)雜項目結(jié)構(gòu)的學(xué)習(xí)成本較高。
如果工程進度非常緊迫,我們可以用簡單粗暴的方式用經(jīng)濟成本來說明原因。
使用接口的成本是不使用接口的成本(包括后續(xù)維護成本)。
如果項目變化很大,部署了模塊,項目不急,使用接口的成本比不使用接口的成本低,雖然早期不使用接口似乎更簡單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢
Action、Dao、DaoImpl、Service、ServiceImpl各自的作用是什么,他們之間有什么關(guān)系?
這是Struts2項目的基本框架。它是一個三層結(jié)構(gòu)。
Action從服務(wù)接口獲取數(shù)據(jù),并負責(zé)處理和過濾網(wǎng)頁中的數(shù)據(jù)。Service是定義接口,serviceimpl是定義接口的實現(xiàn),是函數(shù)代碼的編寫地,它從daoimpl接口獲取數(shù)據(jù),Dao是操作數(shù)據(jù)庫的代碼。簡而言之,action調(diào)用serviceimpl,service實現(xiàn)serviceimpl,serviceimpl調(diào)用daoimpl,Dao實現(xiàn)daoimpl。您可以通過查看三層Struts2結(jié)構(gòu)來了解情況
這是一個SSH架構(gòu)項目嗎?它代表三層。模型是一個實例。服務(wù)提供各種方法。Dao實現(xiàn)了多種方法。Impl指的是實現(xiàn)。服務(wù)和Dao都需要實現(xiàn)。Dao的內(nèi)部方法通常實現(xiàn)為與數(shù)據(jù)庫交互,而model通常是數(shù)據(jù)庫中表的實例