java 分层概念 要点
來源 http://www.cnblogs.com/lkboy/p/4210742.html
service是業(yè)務(wù)層?
action層即作為控制器
DAO?(Data Access Object) 數(shù)據(jù)訪問
?
1.JAVA中Action層,?Service層?,modle層?和?Dao層的功能區(qū)分?(下面所描述的service層就是biz)?
? ? ? 首先這是現(xiàn)在最基本的分層方式,結(jié)合了SSH架構(gòu)。modle層就是對應(yīng)的數(shù)據(jù)庫表的實(shí)體類。
Dao層是使用了Hibernate連接數(shù)據(jù)庫、操作數(shù)據(jù)庫(增刪改查)。
Service(biz)層:引用對應(yīng)的Dao數(shù)據(jù)庫操作,在這里可以編寫自己需要的代碼(比如簡單的判斷)。
Action層:引用對應(yīng)的Service(biz)層,在這里結(jié)合Struts的配置文件,跳轉(zhuǎn)到指定的頁面,當(dāng)然也能接受頁面?zhèn)鬟f的請求數(shù)據(jù),也可以做些計(jì)算處理。
以上的Hibernate,Struts,都需要注入到Spring的配置文件中,Spring把這些聯(lián)系起來,成為一個(gè)整體。
?
其他答案:?
一般java都是三層架構(gòu)?數(shù)據(jù)訪問層(dao)?業(yè)務(wù)邏輯層(biz?或者services)?界面層(ui)?
action?是業(yè)務(wù)層的一部分,是一個(gè)管理器?(總開關(guān))(作用是取掉轉(zhuǎn))(取出前臺(tái)界面的數(shù)據(jù),調(diào)用biz方法,轉(zhuǎn)發(fā)到下一個(gè)action或者頁面)????
模型成(model)一般是實(shí)體對象(把現(xiàn)實(shí)的的事物變成java中的對象)作用是一暫時(shí)存儲(chǔ)數(shù)據(jù)方便持久化(存入數(shù)據(jù)庫或者寫入文件)而是?作為一個(gè)包裹封裝一些數(shù)據(jù)來在不同的層以及各種java對象中使用???
dao是數(shù)據(jù)訪問層??就是用來訪問數(shù)據(jù)庫實(shí)現(xiàn)數(shù)據(jù)的持久化(把內(nèi)存中的數(shù)據(jù)永久保存到硬盤中?其他答案:??
Action是一個(gè)控制器?Dao主要做數(shù)據(jù)庫的交互工作?Modle?是模型?存放你的實(shí)體類?Biz?做相應(yīng)的業(yè)務(wù)邏輯處理 ? ?
2.java中dao層和biz層的區(qū)別是什么??
首先解釋面上意思,service是業(yè)務(wù)層,dao是數(shù)據(jù)訪問層。?
呵呵,這個(gè)問題我曾經(jīng)也有過,記得以前剛學(xué)編程的時(shí)候,都是在service里直接調(diào)用dao,service里面就new一個(gè)dao類對象,調(diào)用,其他有意義的事沒做,也不明白有這個(gè)有什么用,參加工作久了以后就會(huì)知道,業(yè)務(wù)才是工作中的重中之重。?
我們都知道,標(biāo)準(zhǔn)主流現(xiàn)在的編程方式都是采用MVC綜合設(shè)計(jì)模式,MVC本身不屬于設(shè)計(jì)模式的一種,它描述的是一種結(jié)構(gòu),最終目的達(dá)到解耦,解耦說的意思是你更改某一層代碼,不會(huì)影響我其他層代碼,如果你會(huì)像spring這樣的框架,你會(huì)了解面向接口編程,表示層調(diào)用控制層,控制層調(diào)用業(yè)務(wù)層,業(yè)務(wù)層調(diào)用數(shù)據(jù)訪問層。初期也許都是new對象去調(diào)用下一層,比如你在業(yè)務(wù)層new一個(gè)DAO類的對象,調(diào)用DAO類方法訪問數(shù)據(jù)庫,這樣寫是不對的,因?yàn)樵跇I(yè)務(wù)層中是不應(yīng)該含有具體對象,最多只能有引用,如果有具體對象存在,就耦合了。當(dāng)那個(gè)對象不存在,我還要修改業(yè)務(wù)的代碼,這不符合邏輯。好比主板上內(nèi)存壞了,我換內(nèi)存,沒必要連主板一起換。我不用知道內(nèi)存是哪家生產(chǎn),不用知道多大容量,只要是內(nèi)存都可以插上這個(gè)接口使用。這就是MVC的意義。?接下來說你感覺service的意義,其實(shí)因?yàn)槟悻F(xiàn)在做東西分層次不是那么嚴(yán)格,在一個(gè)你們做東西業(yè)務(wù)本身也少,舉個(gè)最簡單的例子,你做一個(gè)分頁的功能,數(shù)據(jù)1000條,你20條在一個(gè)頁,你可以把這個(gè)功能寫成工具類封裝起來,然后在業(yè)務(wù)層里調(diào)用這個(gè)封裝的方法,這才是業(yè)務(wù)里真正干得事,只要沒訪問數(shù)據(jù)庫的,都要在業(yè)務(wù)里寫。??
再有不明白的追問,這是經(jīng)驗(yàn)問題,呵呵,其實(shí)以后你就會(huì)懂。只是剛開始寫的代碼都是有個(gè)請求,我就去數(shù)據(jù)庫取,業(yè)務(wù)幾乎沒有。??
其他優(yōu)秀答案:?
比說你現(xiàn)在用的是SSH框架,做一個(gè)用戶模塊:?
? (1)、假設(shè)現(xiàn)在你做這個(gè)功能會(huì)用到user表和權(quán)限表,那么你前臺(tái)的頁面訪問action,action再去調(diào)用用戶模塊service,用戶模塊service判斷你是操作user表還是權(quán)限表,如果你操作的是user表則service的實(shí)現(xiàn)類就去調(diào)用userDAO。如果是操作的是權(quán)限表則調(diào)用權(quán)限的DAO?
??(2)、也就是說DAO一定是和數(shù)據(jù)庫的每張表一一對應(yīng),而service則不是。明白的沒?其實(shí)你一個(gè)項(xiàng)目一個(gè)service和一個(gè)DAO其實(shí)也一樣可以操作數(shù)據(jù)庫,
只不過那要是表非常多,出問題了,那找起來多麻煩,而且太亂了?
?(3)、好處就是你的整個(gè)項(xiàng)目非常系統(tǒng)化,和數(shù)據(jù)庫的表能一致,而且功能模塊化,這樣以后維護(hù)或者改錯(cuò)比較容易,性能也高一些??
簡單的說DAO層是跟數(shù)據(jù)庫打交道的,service層是處理一些業(yè)務(wù)流程的,??
至于你說的為什么要用service層封裝,我認(rèn)為:一般來說,某一個(gè)程序的有些業(yè)務(wù)流程需要連接數(shù)據(jù)庫,有些不需要與數(shù)據(jù)庫打交道而直接是一些業(yè)務(wù)處理,這樣就需要我們整合起來到service中去,這樣可以起到一個(gè)更好的開發(fā)與維護(hù)的作用,同時(shí)也是MVC設(shè)計(jì)模式中model層功能的體現(xiàn)??
3.java中的action是什么,DAO又是什么??
Action類?是[獲得Form表單數(shù)據(jù),并處理邏輯的類]??
DAO(Data?Access?Object)?是一個(gè)接口實(shí)現(xiàn)[通過SessionFactory獲得操作數(shù)據(jù)庫的會(huì)話,并實(shí)現(xiàn)一些基本的刪除?添加?修改數(shù)據(jù),在servlet中更實(shí)際化業(yè)務(wù)操作]?
?
4.?什么是Pojo類??
簡單的Java對象(Plain?Old?Java?Objects)實(shí)際就是普通JavaBeans,使用POJO名稱是為了避免和EJB混淆起來,?而且簡稱比較直接.?其中有一些屬性及其getter?setter方法的類,有時(shí)可以作為value?object或dto(Data?Transform?Object)來使用.當(dāng)然,如果你有一個(gè)簡單的運(yùn)算屬性也是可以的,但不允許有業(yè)務(wù)方法,也不能攜帶有connection之類的方法。 ?
?
5.pojo類和vo類分別是什么?
vo有兩種說法,一個(gè)是viewObject,一個(gè)是valueObject..
就拿前者來說吧,它只負(fù)責(zé)封裝頁面?zhèn)鬟f過來的數(shù)據(jù),這和PO有些不同..
就拿struts1來說,ActionForm就是一個(gè)典型的viewObject.?而valueObject是頁面與頁面之間的傳遞時(shí)保存值的對象....
總的來說,PO是最終傳給BO以及BO傳個(gè)DAO的東西,他很多情況下與我們真正的數(shù)據(jù)庫表想對應(yīng).
而viewObject是一個(gè)頁面上提交后的數(shù)據(jù),不一定完全和PO的屬性相同....?
總結(jié)
以上是生活随笔為你收集整理的java 分层概念 要点的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: golang go 语言在 window
- 下一篇: 关于大龄程序员的谣言 新手必读