<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    每日一得

    不求多得,只求一得 about java,hibernate,spring,design,database,Ror,ruby,快速開發
    最近關心的內容:SSH,seam,flex,敏捷,TDD
    本站的官方站點是:顛覆軟件

      BlogJava :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
      220 隨筆 :: 9 文章 :: 421 評論 :: 0 Trackbacks

    一、 引子

    這是一個很簡單的模式,卻被非常廣泛的使用。之所以簡單是因為在這個模式中僅僅使用到了繼承關系。

    繼承關系由于自身的缺陷,被專家們扣上了 罪惡 的帽子。 使用委派關系代替繼承關系 盡量使用接口實現而不是抽象類繼承 等等專家警告,讓我們這些菜鳥對繼承 另眼相看

    其實,繼承還是有很多自身的優點所在。只是被大家濫用的似乎缺點更加明顯了。合理的利用繼承關系,還是能對你的系統設計起到很好的作用的。而模板方法模式就是其中的一個使用范例。

    ?

    二、 定義與結構

    GOF 給模板方法( Template Method )模式定義一個操作中的算法的骨架,而將一些步驟延遲到子類中。使得子類可以不改變一個算法的結構即可重定義該算法的某些特定步驟。這里的算法的結構,可以理解為你根據需求設計出來的業務流程。特定的步驟就是指那些可能在內容上存在變數的環節。

    可以看出來,模板方法模式也是為了巧妙解決變化對系統帶來的影響而設計的。使用模板方法使系統擴展性增強,最小化了變化對系統的影響。這一點,在下面的舉例中可以很明顯的看出來。

    來看下這個簡單模式的結構吧:

    1) ??????? AbstractClass (抽象類):定義了一到多個的抽象方法,以供具體的子類來實現它們;而且還要實現一個模板方法,來定義一個算法的骨架。該模板方法不僅調用前面的抽象方法,也可以調用其他的操作,只要能完成自身的使命。

    2) ??????? ConcreteClass (具體類):實現父類中的抽象方法以完成算法中與特定子類相關的步驟。

    ?

    下面是模板方法模式的結構圖。直接把《設計模式》上的圖拿過來用下:

    ?

    三、 舉例

    還是在我剛剛分析完源碼的 JUnit 中找個例子吧。 JUnit 中的 TestCase 以及它的子類就是一個模板方法模式的例子。在 TestCase 這個抽象類中將整個測試的流程設置好了,比如先執行 Setup 方法初始化測試前提,在運行測試方法,然后再 TearDown 來取消測試設置。但是你將在 Setup TearDown 里面作些什么呢?鬼才知道呢!!因此,而這些步驟的具體實現都延遲到子類中去,也就是你實現的測試類中。

    來看下相關的源代碼吧。

    這是 TestCase 中,執行測試的模板方法。你可以看到,里面正像前面定義中所說的那樣,它制定了“算法”的框架——先執行 setUp 方法來做下初始化,然后執行測試方法,最后執行 tearDown 釋放你得到的資源。

    public void runBare() throws Throwable {

    ?????? setUp();

    ?????? try {

    ????????????? runTest();

    ?????? }

    ?????? finally {

    ????????????? tearDown();

    ?????? }

    }

    這 就是上面使用的兩個方法。與定義中不同的是,這兩個方法并沒有被實現為抽象方法,而是兩個空的無為方法(被稱為鉤子方法)。這是因為在測試中,我們并不是 必須要讓測試程序使用這兩個方法來初始化和釋放資源的。如果是抽象方法,則子類們必須給它一個實現,不管用到用不到。這顯然是不合理的。使用鉤子方法,則 你在需要的時候,可以在子類中重寫這些方法。

    protected void setUp() throws Exception {

    }

    protected void tearDown() throws Exception {

    }

    ?

    四、 適用情況

    根據上面對定義的分析,以及例子的說明,可以看出模板方法適用于以下情況:

    1) ??????? 一次性實現一個算法的不變的部分,并將可變的行為留給子類來實現。

    2) ??????? 各子類中公共的行為應被提取出來并集中到一個公共父類中以避免代碼重復。其實這可以說是一種好的編碼習慣了。

    3) ??????? 控制子類擴展。模板方法只在特定點調用操作,這樣就只允許在這些點進行擴展。比如上面 runBare ()方法就只在 runTest 前面適用 setUp 方法。如果你不愿子類來修改你的模板方法定義的框架,你可以采用兩種方式來做:一是在 API 中不體現出你的模板方法;二、將你的模板方法置為 final 就可以了。

    ?????? 可以看出,使用模板方法模式可以將代碼的公共行為提取出來,達到復用的目的。而且,在模板方法模式中,是由父類的模板方法來控制子類中的具體實現。這樣你在實現子類的時候,根本不需要對業務流程有太多的了解。

    ?

    五、 總結

    匆匆忙忙寫完了。希望大家指正!
    posted on 2006-08-29 21:39 Alex 閱讀(258) 評論(0)  編輯  收藏 所屬分類: design
    主站蜘蛛池模板: 国产成人精品日本亚洲18图| 国产亚洲无线码一区二区| 国产成人高清精品免费观看| 国产精品亚洲产品一区二区三区| 久久久久久免费一区二区三区| 亚洲AV无码成人精品区狼人影院| 亚洲国产精品无码久久久不卡| 成人免费视频观看无遮挡| 成人无码精品1区2区3区免费看| 四虎亚洲精品高清在线观看| 久久亚洲精品成人| 亚洲伊人久久精品影院| 亚洲成av人片天堂网老年人| 久久久久久免费视频| 69堂人成无码免费视频果冻传媒| 亚洲视频在线免费| 国产成人无码精品久久久免费 | 国偷自产一区二区免费视频| 深夜免费在线视频| 日韩免费在线中文字幕| 亚洲精品黄色视频在线观看免费资源| 亚洲AV无码专区国产乱码不卡| 久久国产亚洲精品| 亚洲hairy多毛pics大全| 人人狠狠综合久久亚洲| 久久久久亚洲国产AV麻豆| 无码日韩人妻AV一区免费l | 亚洲国产成人久久精品动漫| 久久99国产亚洲精品观看| 亚洲成熟xxxxx电影| 亚洲入口无毒网址你懂的| 国产精品亚洲AV三区| 久久精品成人免费看| 国内大片在线免费看| 亚洲综合亚洲综合网成人| 亚洲三级电影网址| 国产亚洲视频在线播放大全| 无码国产精品一区二区免费3p | 免费福利在线观看| 91黑丝国产线观看免费| 国产性爱在线观看亚洲黄色一级片|