• <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
            <2025年8月>
            272829303112
            3456789
            10111213141516
            17181920212223
            24252627282930
            31123456

            常用鏈接

            留言簿(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++
            久久久久99精品成人片| 久久亚洲春色中文字幕久久久| 99久久免费国产特黄| 99久久国产综合精品五月天喷水| 很黄很污的网站久久mimi色| 久久精品中文无码资源站| 久久天天躁狠狠躁夜夜avapp| 精品久久久无码人妻中文字幕| 久久夜色精品国产亚洲av| 久久无码专区国产精品发布| 日本福利片国产午夜久久| 国产成人精品久久亚洲高清不卡 | 久久影视国产亚洲| 国产美女久久久| 99蜜桃臀久久久欧美精品网站| 91秦先生久久久久久久| 久久精品午夜一区二区福利| 久久乐国产精品亚洲综合| 久久久国产精品福利免费| 亚洲va久久久噜噜噜久久| 国产精品久久久久久久app | 精品国产乱码久久久久软件| 狠色狠色狠狠色综合久久| 亚洲国产美女精品久久久久∴| 亚洲а∨天堂久久精品9966| 国产精品免费看久久久香蕉| 人人狠狠综合久久亚洲88| 青青青国产精品国产精品久久久久 | 久久综合狠狠综合久久97色| 国产精品视频久久久| 伊人久久大香线焦AV综合影院| 亚洲午夜精品久久久久久app| 精品视频久久久久| 久久久久久久久久免免费精品| 精品久久久久中文字幕一区| 久久国产免费直播| 久久久噜噜噜久久中文字幕色伊伊| 精品久久久久久无码人妻热| 久久综合九色综合久99| 亚洲国产精品综合久久网络| 中文国产成人精品久久亚洲精品AⅤ无码精品|