• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            CG@CPPBLOG

            /*=========================================*/
            隨筆 - 76, 文章 - 39, 評論 - 137, 引用 - 0
            數(shù)據(jù)加載中……

            《C++設計新思維》讀書筆記(三)


             
            1.5.1 運用Template Template參數(shù)實作Policy Classes

            如前例,庫代碼host class如果已知policy class,那么可以這樣描述:
            1 
            2 //Library code
            3 template < template < class Created > class CreationPolicy >
            4 class WidgetManager : public CreationPolicy<Widget>{};


            因為Created只是形式引數(shù)(formal argument),不可使用,可以省略如下:
            1 
            2 template < template < class > class CreationPolicy >
            3 class WidgetManager : public CreateionPolicy<Widget>{};


            客戶代碼為:

            1 typedef WidgetManager<OpNewCreator> MyWidgetMgr;


            當WidgetManager希望在內(nèi)部以相同的生成策略產(chǎn)生一個內(nèi)部對象,那么這種template template形式不可或缺。

            Policy的確能夠帶給WidgetManager非常大的彈性。第一,可以外部變更policies。第二,可以自定義policies。

            WidgetManager的作者可以定義一些常用的policies,以“template 缺省引數(shù)”的方式提供:
            1 
            2 template < template < class > class CreationPolicy = OpNewCreator >
            3 class WidgetManager .


            1.5.2 運用Template 成員函數(shù)實作Policy Classes

            我們可以把先前的Creator policy定義為一個非模板類,內(nèi)部提供一個模板成員函數(shù)如下:
             1 
             2 struct OpNewCreator
             3 {
             4      template < class T >
             5      static T* Create()
             6      {
             7             return new T;
             8      }
             9 }
            10 

            這種方式對舊式編譯期有較佳兼容性。但難以討論、定義、實作和運用。

            1.6 更豐富的Policies

            在前例的Creator policy中PrototypeCreateor除了提供Create()成員函數(shù)外,還提供了GetProtoType和SetProtoType兩個函數(shù),由于WidgetManager繼承了policy class,所以WidgetManager具有此兩個接口,雖然它自己并沒有用。

            客戶代碼可以如此:
            1 
            2 typedef WidgetManager<PrototypeCreator> MyWidgetManager;
            3 /////////
            4 widget* pPrototype = ;
            5 MyWidgetManager mgr;
            6 mgr.SetPrototype(pPrototype);


            使用者如果需要擴充policies,可以在不影響host class原本功能的前提下,增加接口。“哪個policy被使用”由使用者決定而非程序庫自身。policies給與使用者一種能力,在型別安全的前提下擴增host class的功能。

             

            posted on 2007-12-17 21:44 cuigang 閱讀(399) 評論(0)  編輯 收藏 引用 所屬分類: 《C++設計新思維》讀書筆記

            久久久久亚洲AV无码网站| 日本久久久精品中文字幕| 狠狠色丁香久久婷婷综合蜜芽五月| 日韩中文久久| 人妻少妇久久中文字幕一区二区| 久久久久久免费一区二区三区| 久久久无码精品亚洲日韩软件| 久久久久国产精品人妻| 97精品国产97久久久久久免费| 热RE99久久精品国产66热| 亚洲va中文字幕无码久久| 狠狠精品久久久无码中文字幕| 久久亚洲日韩看片无码| AAA级久久久精品无码区| 午夜精品久久久久久99热| 青青久久精品国产免费看| 日韩亚洲欧美久久久www综合网| 久久久久久久97| 亚洲国产成人久久综合一区77 | 色婷婷综合久久久久中文字幕| 人妻精品久久无码区| 热综合一本伊人久久精品 | 久久精品国产91久久麻豆自制| 久久综合鬼色88久久精品综合自在自线噜噜| 国产麻豆精品久久一二三| 亚洲中文字幕无码久久2020| 国产精品99久久久久久猫咪| 国产精品一久久香蕉国产线看观看| 波多野结衣久久精品| 午夜福利91久久福利| 久久九九久精品国产| 久久成人精品| 国产亚洲精午夜久久久久久 | 精品久久久久久久久免费影院| 国产成人精品久久亚洲| 久久er国产精品免费观看8| 99久久成人18免费网站| 久久久久99精品成人片| 久久久久久久综合综合狠狠| 久久一区二区三区免费| 模特私拍国产精品久久|