• <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>
            asm, c, c++ are my all
            -- Core In Computer
            posts - 139,  comments - 123,  trackbacks - 0

            /********************************************\
            |????歡迎轉載, 但請保留作者姓名和原文鏈接, 祝您進步并共勉!?????????? |
            \********************************************/


            標準C++ RTTI的仿MFC實現 - 只用2個宏來實現"根據對象名創建對象"

            作者: Jerry Cat
            時間: 2006/05/30
            鏈接:?http://www.shnenglu.com/jerysun0818/archive/2006/05/30/7895.html

            1. 起由:

            C++ RTTI缺乏一些運行時信息即便是C++98這方面也不好使,無法根據對象名直接創建對象. 所以MFC為了實現序列化,從頭構造了自己的RTTI信息,并定義了一整套宏. 具體可以參考MFC源代中一下類和宏的實現:

            CRuntimeClass, CObject, DECLARE_DYNAMIC, IMPLEMENT_DYNAMIC

            2. 需求:
            本人正在寫一個做集成測試的工具,有一個配置哪些case需要做測試的配置文件,類似結構如下:

            <ut>
            ???? <case name="case1"/>
            ???? <case name="case2"/>
            </ut>

            因此當測試工具導入改配置信息時候,必須能夠根據 "case1", "case2"等名字創建相應的Case對象. 顯然C++沒有提供類似的功能.

            3. 實現:
            仿照MFC Serialize的實現,定義一個基類和2個宏. 需要被動態創建的對象從該基類派生,并將2個宏注冊到對象工廠(Factory對象),然后就
            可以用該對象工廠根據對象名創建對象.

            基類和宏的定義:
            class CUTObject
            {
            public:
            ??? virtual ~CUTObject(){}
            ??? virtual void? SetUTName(CFString name);
            ??? virtual CFString GetUTName();
            ??? virtual CUTObject* Clone(){ return NULL; }

            private:
            ??? CFString m_strUTName;
            };

            #define DECLARE_UTOBJECT(className) \
            public: \
            ???????? virtual CUTObject* Clone() \
            ???????? { return new className(); }\
            ???????? static CUTObject* CreateObject() \
            ???????? { return new className(); } \
            ???????? static bool? RegisterObject(CFString utName) \
            ???????? { \
            ??????????? className *pObj = (className*)CreateObject(); \
            ??????????? CUTFactory *pFactory = CUTFactory::Instance(); \
            ??????????? pFactory->RegisterObject(utName, pObj); \
            ??????????? return true; \
            ????????? }

            #define REGISTER_UTOBJECT(utName, className) bool b##className = className::RegisterObject(utName);

            類工廠是一個標準的Singleton模式,提供2個方法 - RegisterObject和CreateObject:
            class CUTFactory
            {
            public:
            ??? static CUTFactory* Instance();

            private:
            ??? CUTFactory();
            ??? CUTFactory(const CUTFactory& other){}
            ??? CUTFactory& operator=(const CUTFactory& other){}

            public:
            ??? bool? RegisterObject(CFString name, CUTObject *pObj);
            ??? CUTObject* CreateObject(CFString name);

            private:
            ??? static CUTFactory* m_pInstance;
            ??? static std::map<CFString, CUTObject*> m_mapObjects;
            };

            4. 小結:

            最關鍵的代碼是:
            #define REGISTER_UTOBJECT(utName, className) bool b##className = className::RegisterObject(utName);

            這行代碼被調用時,對象className將會以utName的名字注冊到對象工廠.

            實際上是簡單調用className::RegisiterObject方法.

            創建一個className的實例,然后將該實例放置到Factory的數組中.
            因為DECLARE_UTOBJECT宏為每個對象定義了Clone方法,所以類工廠可以從該數組中的實例來創建該對象的其他實例.

            至于REGISTER_UTOBJECT為什么要定義一個bool b##className對象,完全是因為這樣寫才能通過編譯器檢查. 編譯器讀到className::RegisterObejct(utName)時候,會認為這是在進行一個函數定義而不是進行一個函數調用. 只有明確指定返回值的情況下,才被認為是函數調用.

            posted on 2006-05-30 19:43 Jerry Cat 閱讀(1341) 評論(0)  編輯 收藏 引用

            <2006年5月>
            30123456
            78910111213
            14151617181920
            21222324252627
            28293031123
            45678910

            常用鏈接

            留言簿(7)

            隨筆檔案

            最新隨筆

            搜索

            •  

            最新評論

            閱讀排行榜

            評論排行榜

            久久久久久久女国产乱让韩| 人妻精品久久无码专区精东影业| 久久亚洲精品成人AV| 国产精品女同久久久久电影院| 青青草国产精品久久久久| 国产巨作麻豆欧美亚洲综合久久| 亚洲国产成人精品久久久国产成人一区二区三区综 | 日韩精品久久久久久免费| 久久99中文字幕久久| 久久人人爽人爽人人爽av| 国内精品久久久久| 99久久精品免费看国产一区二区三区 | 久久国产色AV免费看| 久久av高潮av无码av喷吹| 久久精品人人做人人妻人人玩| 国产偷久久久精品专区| 国产三级观看久久| 99久久无码一区人妻a黑| 久久九九久精品国产免费直播| 久久99热这里只有精品国产| 国产精品9999久久久久| 99久久精品免费看国产一区二区三区 | 色8久久人人97超碰香蕉987| 久久精品这里只有精99品| 日本精品久久久久中文字幕8| 久久精品国产乱子伦| 18禁黄久久久AAA片| 久久国产成人精品国产成人亚洲| 久久99国产精品久久| 成人国内精品久久久久影院| 久久精品国产亚洲AV无码娇色| 亚洲精品乱码久久久久久中文字幕| 久久午夜免费视频| 无码国内精品久久综合88| 亚洲色欲久久久久综合网| 亚洲欧洲久久久精品| 色综合久久夜色精品国产| 午夜精品久久久久成人| 中文字幕久久精品无码| 亚洲av成人无码久久精品| 97r久久精品国产99国产精|