Shao Fan

          關于JAVA與軟件工程
          posts - 31, comments - 71, trackbacks - 0, articles - 4
            BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理

          關于三層架構的一些想法

          Posted on 2007-09-08 19:45 shaofan 閱讀(5132) 評論(2)  編輯  收藏 所屬分類: Java
          目前開發人員對系統開發的一個共識是使用三層架構,分為表示層,業務層,和持久層。而這三層之間的依賴關系如何?比較常見的一種看法是

          表示層 --> 業務層 --> 持久層

          這表明了層與層之間的調用關系,表示層通過調用業務層來完成任務,而業務層則調用持久層。從另一個角度來看,一種依賴關系是

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

          表示層和持久層都應該理解(recognize)領域模型。而領域模型則是業務層的一部分。業務層正是系統的價值所在。雖說表示和持久也很重要,在某些系統中可以說是很關鍵,但是它們的最終目的都是為業務服務,所以業務層應該是系統的核心

          基于以上的認識,在系統設計的時應首先分析需求得到領域模型,找出系統中的實體、對象(靜態的一面),并明確大致的業務流程(動態的一面)。 而另兩層應盡最大努力為業務層服務,且盡量減少業務層受另兩層的限制。


          各層的職責:

          表示層:負責顯示信息,及從系統外部得到輸入。表示層的設計決定系統界面的可用性,及信息輸入和展示的可靠性。表示層只知道如何展示信息,及收集用戶輸入,并不知道該如何對這些輸入進行處理來完成業務。

          業務層:完成業務邏輯。業務層設計決定客戶價值是否能夠得到實現。這是系統的關鍵。外在的表現是功能性。業務層設計和實現的失誤表現在用戶端即功能缺失,功能不可靠等。如果需要對業務層的業務規則進行解耦,則可以使用規則引擎如Drools,把業務規則分離出來。但分離后的業務規則仍屬于業務層。業務層知道如何對用戶輸入進行處理,能夠應用業務規則完成用戶所需的業務,但它不知道數據如何讀取和保存。

          持久層:負責用戶信息的持久化。持久層的失誤表現在外即數據處理(儲存,展示等)不可靠。持久層完全不知道業務,只專注于數據存儲和讀取。所謂持久化并不一定是指數據庫,任何方式的持久化(通過文件,網絡的持久化等)都應由持久層完成。

          各層的設計都會直接影響系統性能。

          三層的體積大小和復雜度在不同的系統中可能會有很大的不同。比如說GOOGLE的搜索引擎,它的界面很簡單,可以想像表示層是比較容易實現的,而它的業務層,關系到處理關鍵字,分析搜索結果,決定排名等,而持久層則要負責處理超大量的數據。業務層和持久層則相當復雜。而有的系統持久層會很小,比如殺毒軟件,媒體播放軟件等。業務層小而另兩層大的例子暫時還沒有想到:)



          評論

          # re: 關于三層架構的一些想法  回復  更多評論   

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

          # re: 關于三層架構的一些想法  回復  更多評論   

          2007-09-10 13:45 by 編程、設計是職業更是愛好
          這幾個層次的劃分沒有嚴格準確的定義,適合的才是最好的。
          主站蜘蛛池模板: 汝南县| 陕西省| 闽侯县| 广宁县| 临清市| 钟山县| 东乌| 德令哈市| 赫章县| 珲春市| 高尔夫| 杂多县| 宿州市| 苏尼特左旗| 三门峡市| 汨罗市| 运城市| 武山县| 东平县| 宽城| 漳浦县| 岗巴县| 亚东县| 临潭县| 新河县| 齐河县| 长沙市| 策勒县| 周至县| 凤庆县| 安塞县| 岚皋县| 富平县| 黔江区| 什邡市| 会昌县| 连江县| 东乡| 竹溪县| 通化市| 理塘县|