• <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, 評(píng)論 - 137, 引用 - 0
            數(shù)據(jù)加載中……

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


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

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


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


            客戶代碼為:

            1 typedef WidgetManager<OpNewCreator> MyWidgetMgr;


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

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

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


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

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

            這種方式對(duì)舊式編譯期有較佳兼容性。但難以討論、定義、實(shí)作和運(yùn)用。

            1.6 更豐富的Policies

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

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


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

             

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

            18岁日韩内射颜射午夜久久成人 | 91久久国产视频| 久久99国产精品久久久| 亚洲综合久久综合激情久久| 国产综合精品久久亚洲| 99精品国产99久久久久久97| 99精品久久精品一区二区| 久久九九免费高清视频| 久久亚洲私人国产精品| 91久久精品视频| 色综合久久久久综合体桃花网| 久久99精品国产麻豆| 欧美一级久久久久久久大片| 99久久精品毛片免费播放| 亚洲成av人片不卡无码久久| 麻豆精品久久精品色综合| 精品人妻伦九区久久AAA片69| 国产精品va久久久久久久| 99精品国产99久久久久久97| 欧美日韩成人精品久久久免费看 | 精品国产乱码久久久久久1区2区| 国产日韩欧美久久| 91精品国产综合久久久久久| 久久婷婷五月综合97色直播| 狠狠色伊人久久精品综合网| 狠狠色丁香婷婷综合久久来| 久久天天躁狠狠躁夜夜96流白浆 | 成人午夜精品无码区久久| 久久国产影院| 国产精品成人精品久久久| 狠狠狠色丁香婷婷综合久久五月 | 一本久久精品一区二区| 久久99精品久久久久久噜噜| 精品国际久久久久999波多野| 久久精品午夜一区二区福利| 婷婷久久久亚洲欧洲日产国码AV | 久久精品国产亚洲AV久| 久久综合狠狠综合久久97色| 狠狠色综合久久久久尤物| 欧洲国产伦久久久久久久| 午夜视频久久久久一区|