Shao Fan

          關(guān)于JAVA與軟件工程
          posts - 31, comments - 71, trackbacks - 0, articles - 4
            BlogJava :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理

          關(guān)于三層架構(gòu)的一些想法

          Posted on 2007-09-08 19:45 shaofan 閱讀(5132) 評(píng)論(2)  編輯  收藏 所屬分類: Java
          目前開發(fā)人員對(duì)系統(tǒng)開發(fā)的一個(gè)共識(shí)是使用三層架構(gòu),分為表示層,業(yè)務(wù)層,和持久層。而這三層之間的依賴關(guān)系如何?比較常見的一種看法是

          表示層 --> 業(yè)務(wù)層 --> 持久層

          這表明了層與層之間的調(diào)用關(guān)系,表示層通過(guò)調(diào)用業(yè)務(wù)層來(lái)完成任務(wù),而業(yè)務(wù)層則調(diào)用持久層。從另一個(gè)角度來(lái)看,一種依賴關(guān)系是

          表示層 --> 領(lǐng)域模型(Domain Model) <-- 持久層

          表示層和持久層都應(yīng)該理解(recognize)領(lǐng)域模型。而領(lǐng)域模型則是業(yè)務(wù)層的一部分。業(yè)務(wù)層正是系統(tǒng)的價(jià)值所在。雖說(shuō)表示和持久也很重要,在某些系統(tǒng)中可以說(shuō)是很關(guān)鍵,但是它們的最終目的都是為業(yè)務(wù)服務(wù),所以業(yè)務(wù)層應(yīng)該是系統(tǒng)的核心

          基于以上的認(rèn)識(shí),在系統(tǒng)設(shè)計(jì)的時(shí)應(yīng)首先分析需求得到領(lǐng)域模型,找出系統(tǒng)中的實(shí)體、對(duì)象(靜態(tài)的一面),并明確大致的業(yè)務(wù)流程(動(dòng)態(tài)的一面)。 而另兩層應(yīng)盡最大努力為業(yè)務(wù)層服務(wù),且盡量減少業(yè)務(wù)層受另兩層的限制。


          各層的職責(zé):

          表示層:負(fù)責(zé)顯示信息,及從系統(tǒng)外部得到輸入。表示層的設(shè)計(jì)決定系統(tǒng)界面的可用性,及信息輸入和展示的可靠性。表示層只知道如何展示信息,及收集用戶輸入,并不知道該如何對(duì)這些輸入進(jìn)行處理來(lái)完成業(yè)務(wù)。

          業(yè)務(wù)層:完成業(yè)務(wù)邏輯。業(yè)務(wù)層設(shè)計(jì)決定客戶價(jià)值是否能夠得到實(shí)現(xiàn)。這是系統(tǒng)的關(guān)鍵。外在的表現(xiàn)是功能性。業(yè)務(wù)層設(shè)計(jì)和實(shí)現(xiàn)的失誤表現(xiàn)在用戶端即功能缺失,功能不可靠等。如果需要對(duì)業(yè)務(wù)層的業(yè)務(wù)規(guī)則進(jìn)行解耦,則可以使用規(guī)則引擎如Drools,把業(yè)務(wù)規(guī)則分離出來(lái)。但分離后的業(yè)務(wù)規(guī)則仍屬于業(yè)務(wù)層。業(yè)務(wù)層知道如何對(duì)用戶輸入進(jìn)行處理,能夠應(yīng)用業(yè)務(wù)規(guī)則完成用戶所需的業(yè)務(wù),但它不知道數(shù)據(jù)如何讀取和保存。

          持久層:負(fù)責(zé)用戶信息的持久化。持久層的失誤表現(xiàn)在外即數(shù)據(jù)處理(儲(chǔ)存,展示等)不可靠。持久層完全不知道業(yè)務(wù),只專注于數(shù)據(jù)存儲(chǔ)和讀取。所謂持久化并不一定是指數(shù)據(jù)庫(kù),任何方式的持久化(通過(guò)文件,網(wǎng)絡(luò)的持久化等)都應(yīng)由持久層完成。

          各層的設(shè)計(jì)都會(huì)直接影響系統(tǒng)性能。

          三層的體積大小和復(fù)雜度在不同的系統(tǒng)中可能會(huì)有很大的不同。比如說(shuō)GOOGLE的搜索引擎,它的界面很簡(jiǎn)單,可以想像表示層是比較容易實(shí)現(xiàn)的,而它的業(yè)務(wù)層,關(guān)系到處理關(guān)鍵字,分析搜索結(jié)果,決定排名等,而持久層則要負(fù)責(zé)處理超大量的數(shù)據(jù)。業(yè)務(wù)層和持久層則相當(dāng)復(fù)雜。而有的系統(tǒng)持久層會(huì)很小,比如殺毒軟件,媒體播放軟件等。業(yè)務(wù)層小而另兩層大的例子暫時(shí)還沒(méi)有想到:)



          評(píng)論

          # re: 關(guān)于三層架構(gòu)的一些想法  回復(fù)  更多評(píng)論   

          2007-09-10 00:08 by 阿牛..,
          好文章,收藏!

          # re: 關(guān)于三層架構(gòu)的一些想法  回復(fù)  更多評(píng)論   

          2007-09-10 13:45 by 編程、設(shè)計(jì)是職業(yè)更是愛好
          這幾個(gè)層次的劃分沒(méi)有嚴(yán)格準(zhǔn)確的定義,適合的才是最好的。
          主站蜘蛛池模板: 合水县| 宝坻区| 兖州市| 比如县| 冕宁县| 广丰县| 信宜市| 措美县| 霍山县| 永安市| 铜山县| 大洼县| 鱼台县| 大同县| 玉溪市| 竹山县| 怀来县| 江川县| 尖扎县| 新邵县| 封开县| 屏山县| 翁牛特旗| 东城区| 利津县| 堆龙德庆县| 安岳县| 修文县| 两当县| 称多县| 达州市| 洪湖市| 偏关县| 潜山县| 南昌市| 安丘市| 迁西县| 张北县| 体育| 仲巴县| 瓮安县|