• <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 閱讀(642) 評論(0)  編輯 收藏 引用 所屬分類: 《C++設計新思維》讀書筆記

            久久精品综合网| 99麻豆久久久国产精品免费| 夜夜亚洲天天久久| 品成人欧美大片久久国产欧美| 人妻无码久久一区二区三区免费| 人妻少妇久久中文字幕一区二区| 热re99久久精品国产99热| 久久激情亚洲精品无码?V| 中文字幕精品无码久久久久久3D日动漫| 国产精品99久久久久久宅男| 欧美精品丝袜久久久中文字幕 | 久久精品国产精品亜洲毛片| 中文字幕无码久久人妻| 久久66热人妻偷产精品9| 99热热久久这里只有精品68| 久久福利资源国产精品999| 久久777国产线看观看精品| 久久精品18| 久久久久久亚洲精品成人| 久久一区二区免费播放| 免费观看成人久久网免费观看| 三级片免费观看久久| 国产一区二区精品久久| 久久亚洲精品无码AV红樱桃| 岛国搬运www久久| 久久久噜噜噜久久熟女AA片| 久久久久99精品成人片牛牛影视 | 久久综合88熟人妻| 久久国产精品无| 国产成人精品久久综合| 国产精品久久久久久久久| 久久久这里有精品| 精品久久久久久久中文字幕| 午夜精品久久久久久99热| 人人妻久久人人澡人人爽人人精品| 99久久精品免费国产大片| 欧美亚洲国产精品久久蜜芽| 日韩av无码久久精品免费| 久久精品国产久精国产思思| av午夜福利一片免费看久久| 久久99精品久久久久久久不卡|