乡下人产国偷v产偷v自拍,国产午夜片在线观看,婷婷成人亚洲综合国产麻豆,久久综合给合久久狠狠狠9

  • <output id="e9wm2"></output>
    <s id="e9wm2"><nobr id="e9wm2"><ins id="e9wm2"></ins></nobr></s>

    • 分享

      Duwamish深入剖析-結(jié)構(gòu)篇

       liuqg 2006-03-10
       
      Duwamish深入剖析-結(jié)構(gòu)篇

      摘要:
      本文深入詳細的介紹了Duwamish網(wǎng)上電子書店例程的結(jié)構(gòu)框架,并詳細的分析了該結(jié)構(gòu)的若干特點和設(shè)計模式。

      目錄:
      引言
      Duwamish介紹
      結(jié)構(gòu)分析
      設(shè)計思想
      代碼示例
      總結(jié)

      引言:
      能夠作為Visual Studio .Net附帶的例子,Duwamish一定包含了微軟.Net設(shè)計隊伍希望向開發(fā)者傳達的某些信息,而事實上,Duwamish也的確能夠稱作是一個.Net開發(fā)者學習的經(jīng)典示例,無論是從其設(shè)計架構(gòu),編程技巧或代碼風格,都向我們展示了一個標準的.Net企業(yè)級應用程序所應該具有的特點。所以,通過研究Duwamish示例,高手能夠領(lǐng)悟到.Net應用架構(gòu)的設(shè)計思想,低手能夠?qū)W習到.Net的編程技巧,實在是老少皆宜。 :)
      不過,本文的目的更多的是針對中級.Net學習者,這類讀者往往已經(jīng)熟悉了C#或者是VB.NET的語法,會用一些基本的類庫,并已經(jīng)會做一些比較小的程序。但是當他們開始著手開發(fā)一個真正具有實用價值的企業(yè)級應用的時候,卻有種無處下手的感覺。如果你正巧屬于這類學習者,請跟著我深入到Duwamish的世界中去,相信你一定會得到收獲。

      Duwamish介紹:
      Microsoft公司每次推出新技術(shù),總是會相應的推出一些公開源代碼的應用范例來說明該項新技術(shù)的特點,而開發(fā)者也能通過研究該范例的代碼來達到迅速掌握新技術(shù)并與以實施的目的。Microsoft通過對一個虛擬的在網(wǎng)上銷售圖書的電子商務公司網(wǎng)上銷售系統(tǒng)應用的創(chuàng)建,向用戶展現(xiàn)了典型的網(wǎng)上購物實踐中最為普遍的電子商務企業(yè)對客戶 (B2C) 模式,它包括成員資格、帳戶管理、購物車、搜索和結(jié)帳過程等基本功能。Duwamish經(jīng)歷了三個版本4.0,5.0和7.0版,每一個版本的發(fā)布都印證了技術(shù)進步的過程,每一個版本都代表了當時最先進的技術(shù)動向。這里將要研究和討論的是Duwamish的最高版本7.0版,經(jīng)歷了COM/COM+技術(shù)以及Microsoft DNA架構(gòu)的Duwamish,在最新的版本中完全采用了.Net技術(shù)及架構(gòu),比以前顯得更加先進和成熟。


      如果您安裝了Visual Studio .Net的話,您可以在您的VS.Net 的Enterprise Samples目錄下找到并安裝它,例如:C:\Program Files\Microsoft Visual Studio .NET\Enterprise Samples\,或者您還可以到http:///Duwamish7Vb/這個地址去看看它在Internet的一個演示實例。其它有關(guān)Duwamish的詳細介紹資料請參考Visual Studio .Net附帶的MSDN幫助,地址是:ms-help://MS.VSCC/MS.MSDNVS.2052/dwamish7/html/vtoriDuwamishBooks70.htm,這里不再贅述。

      Duwamish結(jié)構(gòu)分析:
      Duwamish 7.0 是一個典型的N層架構(gòu),其結(jié)構(gòu)分為四個邏輯層:
      Web 層
      Web 層為客戶端提供對應用程序的訪問。這一層是作為 Duwamish.sln 解決方案文件中的 Web 項目實現(xiàn)的。Web 層由 ASP.NET Web 窗體和代碼隱藏文件組成。Web 窗體只是用 HTML 提供用戶操作,而代碼隱藏文件實現(xiàn)各種控件的事件處理。
      業(yè)務外觀層
      業(yè)務外觀層為 Web 層提供處理帳戶、類別瀏覽和購書的界面。這一層是作為 Duwamish.sln 解決方案文件中的 BusinessFacade 項目實現(xiàn)的。業(yè)務外觀層用作隔離層,它將用戶界面與各種業(yè)務功能的實現(xiàn)隔離開來。除了低級系統(tǒng)和支持功能之外,對數(shù)據(jù)庫服務器的所有調(diào)用都是通過此程序集進行的。
      業(yè)務規(guī)則層
      業(yè)務規(guī)則層是作為 Duwamish.sln 解決方案文件中的 BusinessRules 項目實現(xiàn)的,它包含各種業(yè)務規(guī)則和邏輯的實現(xiàn)。業(yè)務規(guī)則完成如客戶帳戶和書籍訂單的驗證這樣的任務。
      數(shù)據(jù)訪問層
      數(shù)據(jù)訪問層為業(yè)務規(guī)則層提供數(shù)據(jù)服務。這一層是作為 Duwamish.sln 解決方案文件中的 DataAccess 項目實現(xiàn)的。
      比較令人困惑的是其中的業(yè)務外觀層和業(yè)務規(guī)則層,很多人在學習N層結(jié)構(gòu)開發(fā)的時候,聽得最多的是三層結(jié)構(gòu),分別為:表示層,中間層和數(shù)據(jù)層。Duwamish的WEB層和數(shù)據(jù)訪問層比較好理解,也就是傳統(tǒng)意義上的表示層和數(shù)據(jù)層,那么業(yè)務外觀層和業(yè)務規(guī)則層和我們熟悉的中間層有什么聯(lián)系呢?

      設(shè)計思想:
      在Web應用程序中,有部分操作只是簡單的從數(shù)據(jù)庫根據(jù)條件提取數(shù)據(jù),不需要經(jīng)過任何處理,而直接將數(shù)據(jù)顯示到網(wǎng)頁上,比如查詢某類別的圖書列表。而另外一些操作,比如計算定單中圖書的總價并根據(jù)顧客的級別計算回扣等等,這部分往往有許多不同的功能的類,操作起來也比較復雜。我們可以先想象一下,如果我們采用三層結(jié)構(gòu),這些商業(yè)邏輯一般是會放在中間層,那么對內(nèi)部的這些大量種類繁多,使用方法也各異的不同的類的調(diào)用任務,就完全落到了表示層。這樣勢必會增加表示層的代碼量,將表示層的任務復雜化,和表示層只負責接受用戶的輸入并返回結(jié)果的任務不太相稱,并增加了層與層之間的耦合程度。
      為了解決這個問題,我們先來看看《設(shè)計模式》一文中對Facade模式的描述:
      意圖:
      為子系統(tǒng)中的一組接口提供一個一致的界面,F(xiàn)acade模式定義了一個高層接口,這個接口使得這一子系統(tǒng)更加容易使用。
      適用性:
      當你要為一個復雜子系統(tǒng)提供一個簡單接口時。子系統(tǒng)往往因為不斷演化而變得越來越復雜。大多數(shù)模式使用時都會產(chǎn)生更多更小的類。這使得子系統(tǒng)更具可重用性,也更容易對子系統(tǒng)進行定制,但這也給那些不需要定制子系統(tǒng)的用戶帶來一些使用上的困難。Facade可以提供一個簡單的缺省視圖,這一視圖對大多數(shù)用戶來說已經(jīng)足夠,而那些需要更多的可定制性的用戶可以越過Facade層。
      客戶程序與抽象類的實現(xiàn)部分之間存在著很大的依賴性。引入Facade將這個子系統(tǒng)與客戶以及其他的子系統(tǒng)分離,可以提高子系統(tǒng)的獨立性和可移植性。
      當你需要構(gòu)建一個層次結(jié)構(gòu)的子系統(tǒng)時,使用Facade模式定義子系統(tǒng)中每層的入口點。如果子系統(tǒng)之間是相互依賴的,你可以讓它們僅通過Facade進行通訊,從而簡化了它們之間的依賴關(guān)系。
      結(jié)構(gòu)圖:


      上文提出的這個矛盾,正好和設(shè)計模式中Facade模式中所描述的需要解決的問題非常吻合,在《設(shè)計模式》中提出的解決的辦法就是引入一個Facade對象,讓這個Fa&ccedil;ade來負責管理系統(tǒng)內(nèi)部類的調(diào)用,并為表示層提供了一個單一而簡單的接口。這個Fa&ccedil;ade對象,在我們的Duwamish的設(shè)計中,就是BusinessFacade(業(yè)務外觀)層。
      以下是Duwamish的結(jié)構(gòu)關(guān)系圖:


      我們從圖中可以清楚的看到,瀏覽器首先調(diào)用的是表示層WEB,然后WEB將請求發(fā)送給業(yè)務外觀層,業(yè)務外觀層對請求進行初步的處理,判斷是否需要調(diào)用業(yè)務規(guī)則層,還是直接調(diào)用數(shù)據(jù)訪問層獲取數(shù)據(jù)。最后由數(shù)據(jù)訪問層訪問數(shù)據(jù)庫并按照來時的步驟返回結(jié)果到瀏覽器(對于圖中涉及到其它的結(jié)構(gòu)模塊以后會分別予以詳細介紹)。

      代碼示例:
      以下是兩種不同處理路徑的代碼示例:
      獲取商品目錄
      表示層調(diào)用業(yè)務外觀層:
      productSystem = new ProductSystem();
      categorySet = productSystem.GetCategories(categoryID);
      業(yè)務外觀層直接調(diào)用數(shù)據(jù)層:
      public CategoryData GetCategories(int categoryId)
      {
      if ( dsCommand == null )
      {
      throw new System.ObjectDisposedException( GetType().FullName );
      }
      return FillCategoryData("GetCategories", "@CategoryId", categoryId);
      }
      
      添加定單
      表示層調(diào)用業(yè)務外觀層:
      public void AddOrder()
      {
      ApplicationAssert.CheckCondition(cartOrderData != null, "Order requires data",
      ApplicationAssert.LineNumber);
      ApplicationLog.WriteTrace("Duwamish7.Web.Cart.AddOrder:\r\nCustomerId: " +
      cartOrderData.Tables[OrderData.CUSTOMER_TABLE].Rows[0][OrderData.PKID_FIELD].ToString());
      cartOrderData = (new OrderSystem()).AddOrder(cartOrderData);
      }
      
      業(yè)務外觀層調(diào)用業(yè)務規(guī)則層:
      public OrderData AddOrder(OrderData order)
      {
      ApplicationAssert.CheckCondition(order != null, "Order is required",
      ApplicationAssert.LineNumber);
      (new BusinessRules.Order()).InsertOrder(order);
      return order;
      }
      
      業(yè)務規(guī)則層調(diào)用數(shù)據(jù)層:
      public bool InsertOrder(OrderData order)
      {
      //此處省略復雜的處理邏輯
      if ( isValid )
      {
      using (DataAccess.Orders ordersDataAccess = new DataAccess.Orders())
      {
      return (ordersDataAccess.InsertOrderDetail(order)) > 0;
      }
      }
      else
      return false;
      }
      

      總結(jié):
      通過分析Duwamish7的結(jié)構(gòu)設(shè)計,我們掌握了Fa&ccedil;ade模式,并學習到了如何通過Fa&ccedil;ade模式對應用結(jié)構(gòu)進行改進,同時了解了Duwamish7的基本概念和處理流程,為以后深入分析和學習Duwamish7的的其它部分打下了一個基礎(chǔ)

      - 作者: Falcon 2006年02月7日, 星期二 14:04  回復(2) |  引用(0)

        本站是提供個人知識管理的網(wǎng)絡存儲空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點。請注意甄別內(nèi)容中的聯(lián)系方式、誘導購買等信息,謹防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請點擊一鍵舉報。
        轉(zhuǎn)藏 分享 獻花(0

        0條評論

        發(fā)表

        請遵守用戶 評論公約

        類似文章 更多