• <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
            數據加載中……

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

            《C++設計新思維》讀書筆記(二)
             
            1.5 Policies和Policy Classes

            舉例,定義一個policy生成對象:Creator policy 提供一個Create函數,返回一個指向新生T類型對象的指針。

            我們有三種做法:

             1 template<class T>
             2 struct OpNewCreator{
             3      static T* Create(){
             4           return New T;
             5      }
             6 };
             7 template <class T>
             8 struct MallocCreator{
             9      static T* Create(){
            10            void* buf = std::malloc(sizeof(T));
            11            if(!buf) return 0;
            12            return new(buf) T;     //定位new表達式,見《C++ primer》8.4.5, cuigang
            13       }
            14 };
            15 template <class T>
            16 struct PrototypeCreator{
            17       PrototypeCreator(T* pObj =0):pPrototype_(pObj){}
            18       T* Create(){
            19             return pPrototype_? pPrototype_->Clone():0;
            20       }
            21       T* GetPrototype(){ return pPrototype_;}
            22       void SetPrototype(T* pObj){pPrototype_ = pObj;}
            23 private:
            24       T* pPrototype_;
            25 };
            26 

            這些實作出來的policy稱為policy classes,這個東西并不意圖被單獨使用,它們主要用于繼承或被內含于其它classes。

            一個類以復合或繼承的方式使用先前定義的三個classes之一,例如

            1 //Library code
            2 template <class CreationPolicy>
            3 class WidgetManager : public CreationPolicy{};


            如果class采用一個或多個policies,我們稱為hosts或host classes。

            客戶端如此實例化:

            1 //Application code
            2 typedef WidgetManager< OpNewCreator<widget> > MywidgetMgr;


            讓我們分析整個來龍去脈。無論何時,當一個MywidgetMgr對象需要產生一個widget對象時,它便調用它的policy子對象OpNewCreator<widget>所提供的Createv()。選擇“生成策略”(Creation policy)是WidgetManager使用者的權利。藉由這樣的設計,可以讓WidgetManager使用者自行裝配他所需要的機能。

            這便是Policy-based class的設計主旨。
             
            ==============================
            1 template <class T>
            2 void* buf = std::malloc(sizeof(T));
            3 void* buf =  (void*)new T;

            當T為基類,具有派生類時,兩者申請的內存大小是不一致的,sizeof(T)不包括 virtual table 的大小。
            ——鐘遙
             
            //////////////////////////////
            鐘遙過慮了,以下代碼
             1 struct base{
             2         int x;
             3         base(){
             4                 std::cout<< "create a base."<<std::endl;
             5         }
             6         virtual void foo(){
             7                 std::cout<<"call base"<<std::endl;
             8         };
             9 };
            10 struct test : public base{
            11         int y;
            12         test(){
            13                 std::cout<< "create a test."<<std::endl;
            14         }
            15         virtual void foo(){
            16                 std::cout<<"call test."<<std::endl;
            17         }
            18         void foo2(){};
            19 };
            20 /////////////////////////
            21         int a = sizeof(test);
            22         int b = sizeof(base);
            23         std::cout<<"sizeof(test)="<< a << ""<<"sizeof(base)=" << b << endl;
            24         base* pa = new base;
            25         base* pb = new test;
            26         std::cout<<"---------"<<endl;
            27         base* ppa = (base*)malloc(sizeof(base));
            28         base* ppb = (base*)malloc(sizeof(test));
            29         std::cout<<"---------"<<endl;
            30         new(ppa) base;
            31         new(ppb) test;
            32         pa->foo();
            33         pb->foo();
            34         ppa->foo();
            35         ppb->foo();


            輸出結果:
             1 sizeof(test)=12, sizeof(base)=8
             2 create a base.
             3 create a base.
             4 create a test.
             5 ---------
             6 ---------
             7 create a base.
             8 create a base.
             9 create a test.
            10 call base
            11 call test.
            12 call base
            13 call test.

             
             

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

            国产精品9999久久久久| 久久久久久久综合日本| 99久久国产亚洲综合精品| 久久青青色综合| 精品免费久久久久久久| 91精品国产91久久久久久| 久久午夜福利电影| 国产午夜福利精品久久2021| 国产成人精品久久| 久久久久久综合网天天| 天天爽天天爽天天片a久久网| 性做久久久久久免费观看| 97久久天天综合色天天综合色hd| 国产福利电影一区二区三区久久老子无码午夜伦不 | 亚洲伊人久久精品影院| 久久精品国产69国产精品亚洲| 久久精品国产亚洲Aⅴ香蕉 | 久久天堂电影网| 久久人人爽人人爽人人片AV东京热 | 久久青青草原综合伊人| 性做久久久久久久| 亚洲午夜无码久久久久小说| 久久精品国产精品国产精品污| 国产69精品久久久久久人妻精品 | 青青草原精品99久久精品66| 国产精品美女久久久久AV福利| 无码人妻少妇久久中文字幕蜜桃| 久久精品国产99久久丝袜 | 日韩影院久久| 色综合久久天天综合| 免费精品99久久国产综合精品| 久久国产精品99精品国产| 午夜精品久久久久久久久| 久久亚洲AV无码精品色午夜| 色综合久久久久综合99| 亚洲国产成人乱码精品女人久久久不卡 | 久久精品国产秦先生| 久久精品国产影库免费看| 2020久久精品国产免费| 久久久女人与动物群交毛片| 无码国内精品久久人妻蜜桃|