springmvc常用5種注解 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)單;相反,不使用接口的成本低,而且連框架都不能用~
畢竟工具是提高效率的,那你為什么不能和自己相處呢
springmvc的工作流程是什么?
Spring工作流1。用戶(hù)向前端控制器(DispatcherServlet)發(fā)出請(qǐng)求,前端控制器將過(guò)濾出哪些請(qǐng)求可以訪問(wèn)servlet,哪些請(qǐng)求不能訪問(wèn)。是URL模式的角色,并將加載springmvc.xml文件配置文件。2前端控制器將找到處理程序映射,并通過(guò)處理程序映射完成URL到控制器的映射組件。簡(jiǎn)而言之,它會(huì)的springmvc.xml文件查找并存儲(chǔ)中配置或注釋的URL以及相應(yīng)的處理類(lèi)。使用map
說(shuō)出想法,然后自己編寫(xiě)每一層的代碼。首先,我們需要通過(guò)視圖層來(lái)查詢(xún)條件,使用用戶(hù)提交請(qǐng)求,用表單接收查詢(xún)條件,post提交給相應(yīng)spring MVC的控制器;控制器接受參數(shù),調(diào)用業(yè)務(wù)邏輯層(服務(wù)層)方法,業(yè)務(wù)邏輯層處理這些參數(shù),然后將它們發(fā)送到數(shù)據(jù)訪問(wèn)層(Dao層)在數(shù)據(jù)庫(kù)中進(jìn)行查詢(xún)。查詢(xún)數(shù)據(jù)返回到服務(wù)層,然后返回到控制器。然后我們可以讓控制器模型攜帶數(shù)據(jù)并將其轉(zhuǎn)發(fā)到一個(gè)視圖,以便向用戶(hù)顯示信息!