• <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>
            隨筆 - 132  文章 - 51  trackbacks - 0
            <2012年7月>
            24252627282930
            1234567
            891011121314
            15161718192021
            22232425262728
            2930311234

            常用鏈接

            留言簿(7)

            隨筆分類

            隨筆檔案

            文章分類

            文章檔案

            cocos2d-x

            OGRE

            OPenGL

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            1.應用:
            也許需要一個腳本,腳本中有一個參數傳遞類名,你需要通過類名來動態的創建這個對象,這時候就需要動態創建了

             2.原理:
            C++不是動態語言,所以沒法從語言機制上實現類的動態創建,但這樣的需求卻有可能存在,一個類似的例子便是MFC中CWnd類的Create方法,其第一個參數為Window Class的名字,這就允許用戶通過class的名字來創建相應的窗口。
             要想實現這一點,必須有一個“管理中心”,用于登記類的名字,并且通過名字能夠調用對應的創建方法來創建相應的實例。結合類工廠的設計思想,這里我們讓一套繼承體系中的基類作為“管理中心”,由它來維護所有派生類的必要信息,包括類名和工廠函數,這二者必須建立起映射關系,map是不錯的選擇。定義了一個派生類后,它就自動向基類進行注冊

            3.實現:
            可以用宏來代替:
            /*
                實現原理:
                基類里面用map管理所有需要動態創建 【類名-創建對象的函數指針】
                基類聲明中需要添加 DECLEAR_DYNCRT_BASE 宏,cpp實現中要添加 IMPLEMENT_DYNCRT_BASE 宏
                派生類聲明中需要添加 DECLEAR_DYNCRT_CLASS 宏,cpp實現中要添加 IMPLEMENT_DYNCRT_CLASS 宏
                派生類宏中創建了一個全局對象向基類map中注冊【類名-創建對象的函數指針】
                
            */
            #include <map>


            // 聲明具有動態創建的基類
            #define DECLEAR_DYNCRT_BASE(base) \
            public: \
            typedef base* (*ClassGen)(); \
            static void _register(const char* class_name, ClassGen class_gen) \
            { \
                class_set.insert(std::map<const char*, ClassGen>::value_type(class_name, class_gen)); \
            } \
            static base* create(const char* class_name) \
            { \
                std::map<const char*, ClassGen>::iterator it = class_set.find(class_name);   \
                if (it != class_set.end()) \
                    return (it->second)(); \
                return NULL; \
            } \
            protected: \
            static std::map<const char*, ClassGen> class_set;

            // 用于實現基類
            #define IMPLEMENT_DYNCRT_BASE(base) \
            std::map<const char*, base::ClassGen> base::class_set;


            // 用于聲明一個能夠被動態創建的類(用一個全局對象進行注冊)
            #define DECLEAR_DYNCRT_CLASS(derived, base) \
            public: \
                struct derived##register \
                { \
                    derived##register() \
                    { \
                        static bool bRegister = false; \
                        if (!bRegister) \
                        { \
                            base::_register(#derived, _CreateObjectByName); \
                            bRegister = true; \
                        } \
                    } \
                }; \
                static base* _CreateObjectByName() \
                { \
                    return new derived; \
                }


            // 用于實現一個能被動態創建的類
            #define IMPLEMENT_DYNCRT_CLASS(derived) \
                static derived::derived##register _##derived##global_object;

            我們需要做的就是是哦那個這四個宏
            附加上測試代碼:
            // 測試實例:
            class Base
            {
                DECLEAR_DYNCRT_BASE(Base)
                DECLEAR_DYNCRT_CLASS(Base, Base)
            public:
                virtual void Print()
                {
                    std::cout << "This is base!" << std::endl;
                }
            };

            IMPLEMENT_DYNCRT_BASE(Base)
            IMPLEMENT_DYNCRT_CLASS(Base)


            class Derived : public Base
            {
                DECLEAR_DYNCRT_CLASS(Derived, Base)
            public:
                virtual void Print()
                {
                    cout << "This is derived!" << endl;
                }
            };
            IMPLEMENT_DYNCRT_CLASS(Derived)


            int main()
            {
                Base* base = Base::create("Base");
                if (base)
                    base->Print();

                system("pause");
                return 0;
            }


            參考地址:http://blog.csdn.net/freefalcon/article/details/109275 


            posted on 2012-08-30 12:15 風輕云淡 閱讀(2146) 評論(0)  編輯 收藏 引用 所屬分類: C++
            欧美激情精品久久久久| 久久精品国产亚洲av麻豆色欲| 91视频国产91久久久| 精品永久久福利一区二区| 人人狠狠综合久久亚洲88| 亚洲国产成人久久综合野外| 亚洲国产精品无码久久久蜜芽| 国产精品激情综合久久| 久久久久久久久久久| 国产叼嘿久久精品久久| 亚洲中文字幕无码久久综合网 | 人妻少妇精品久久| 久久精品国产第一区二区三区 | 国内精品久久久久久不卡影院| 久久久精品国产| 国产成人久久精品麻豆一区| 久久99亚洲网美利坚合众国| 亚洲七七久久精品中文国产| 狠狠色噜噜狠狠狠狠狠色综合久久| 久久精品中文无码资源站| 91精品国产高清久久久久久91 | 青青草国产97免久久费观看| 久久久综合九色合综国产| 波多野结衣AV无码久久一区| 久久影院午夜理论片无码| 国产精品成人久久久久三级午夜电影| 精品无码久久久久久午夜| 久久久一本精品99久久精品88| 漂亮人妻被中出中文字幕久久 | 国产色综合久久无码有码| 久久久久久青草大香综合精品| 亚洲成色999久久网站| 日韩一区二区久久久久久| 久久96国产精品久久久| 国产情侣久久久久aⅴ免费| 国内精品久久久人妻中文字幕| 中文字幕无码久久精品青草| 中文字幕亚洲综合久久菠萝蜜| 欧美久久综合九色综合| 少妇久久久久久被弄到高潮 | 久久精品国产国产精品四凭|