• <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年10月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(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 風輕云淡 閱讀(2133) 評論(0)  編輯 收藏 引用 所屬分類: C++
            久久国产高清字幕中文| 欧美日韩精品久久久久| 久久伊人精品一区二区三区| 国产AⅤ精品一区二区三区久久| 亚洲午夜精品久久久久久人妖| 尹人香蕉久久99天天拍| 久久99国产综合精品| 久久精品夜色噜噜亚洲A∨| 国产亚洲美女精品久久久2020| 久久99国产精品尤物| 国产精品伊人久久伊人电影| 麻豆久久久9性大片| 久久久精品一区二区三区| 精品久久久一二三区| 久久99国产综合精品女同| 免费一级做a爰片久久毛片潮| 久久久国产精品网站| 国内精品久久久久影院亚洲| MM131亚洲国产美女久久| 久久久久久久综合综合狠狠| 99久久99这里只有免费费精品| 欧美日韩精品久久久久| 国产精品岛国久久久久| 新狼窝色AV性久久久久久| 7777久久久国产精品消防器材| 国产巨作麻豆欧美亚洲综合久久| 亚洲va中文字幕无码久久不卡| 一本大道久久香蕉成人网| 久久精品成人一区二区三区| 久久精品国产亚洲综合色| 国产欧美久久一区二区| 国产精品一区二区久久| 91精品国产综合久久婷婷| 性高湖久久久久久久久| 亚洲va久久久噜噜噜久久| 综合人妻久久一区二区精品| 久久人人爽人人人人爽AV| 久久无码人妻一区二区三区午夜 | 亚洲精品无码久久久久去q | 欧美激情精品久久久久久| 久久综合一区二区无码|