• <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>

            李帥的博客

            軟件開發愛好者

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              14 隨筆 :: 3 文章 :: 4 評論 :: 0 Trackbacks
            摘要:

              RTTI(Run-Time Type Identification)是面向對象程序設計中一種重要的技術。現行的C++標準對RTTI已經有了明確的支持。不過在某些情況下出于特殊的開發需要,我們需要自己編碼來實現。本文介紹了一些關于RTTI的基礎知識及其原理和實現。  

            RTTI需求:

              和很多其他語言一樣,C++是一種靜態類型語言。其數據類型是在編譯期就確定的,不能在運行時更改。然而由于面向對象程序設計中多態性的要求,C++中的指針或引用(Reference)本身的類型,可能與它實際代表(指向或引用)的類型并不一致。有時我們需要將一個多態指針轉換為其實際指向對象的類型,就需要知道運行時的類型信息,這就產生了運行時類型識別的要求。

              C++對RTTI的支持

              C++提供了兩個關鍵字typeid和dynamic_cast和一個type_info類來支持RTTI:

              dynamic_cast操作符:它允許在運行時刻進行類型轉換,從而使程序能夠在一個類層次結構安全地轉換類型。dynamic_cast提供了兩種轉換方式,把基類指針轉換成派生類指針,或者把指向基類的左值轉換成派生類的引用。見下例講述:

            void company::payroll(employee *pe) {
            //對指針轉換失敗,dynamic_cast返回NULL
            if(programmer *pm=dynamic_cast(pe)){
            pm->bonus();
            }
            }
            void company::payroll(employee &re) {
            try{
            //對引用轉換失敗的話,則會以拋出異常來報告錯誤
            programmer &rm=dynamic_cast(re);
            pm->bonus();
            }
            catch(std::bad_cast){

            }
            }

              這里bonus是programmer的成員函數,基類employee不具備這個特性。所以我們必須使用安全的由基類到派生類類型轉換,識別出programmer指針。

              typeid操作符:它指出指針或引用指向的對象的實際派生類型。

              例如:

            employee* pe=new manager;
            typeid(*pe)==typeid(manager) //true
              typeid可以用于作用于各種類型名,對象和內置基本數據類型的實例、指針或者引用,當作用于指針和引用將返回它實際指向對象的類型信息。typeid的返回是type_info類型。

              type_info類:這個類的確切定義是與編譯器實現相關的,下面是《C++ Primer》中給出的定義(參考資料[2]中談到編譯器必須提供的最小信息量):

            class type_info {
            private:
            type_info(const type_info&);
            type_info& operator=( const type_info& );
            public:
            virtual ~type_info();
            int operator==( const type_info& ) const;
            int operator!=( const type_info& ) const;
            const char* name() const;
            };
             實現目標:

              實現的方案

              方案一:利用多態來取得指針或應用的實際類型信息

              這是一個最簡單的方法,也是作者目前所采用的辦法。

              實現:

            enum ClassType{
            UObjectClass,
            URectViewClass,
            UDialogClass,
            ……
            };
            class UObject{
            virtual char* GetClassName() const {
            return "UObject";
            };
            virtual ClassType TypeOfClass(){
            return UObjectClass;
            };
            };
            class UDialog{
            virtual char* GetClassName() const {
            return "UDialog";
            };
            virtual ClassType TypeOfClass(){
            return UDialogClass;
            };
            };
              示例:

            UObject po=new UObject;
            UObject pr=new URectView;
            UObject pd=new UDialog;
            cout << "po is a " << po->GetClassName() << endl;
            cout << "pr is a " << pr->GetClassName() << endl;
            cout << "pd is a " << pd->GetClassName() << endl;
            cout<TypeOfClass()==UObjectClass<
            posted on 2008-11-07 21:44 李帥 閱讀(302) 評論(0)  編輯 收藏 引用
            国产精品一区二区久久精品| 亚洲国产精品18久久久久久| 久久成人18免费网站| 久久久久久国产a免费观看不卡| 久久久久香蕉视频| 香蕉久久av一区二区三区| 精品久久久久久无码中文字幕一区| 久久777国产线看观看精品| 久久香蕉国产线看观看猫咪?v| 日日噜噜夜夜狠狠久久丁香五月| 免费观看成人久久网免费观看| 久久久久亚洲AV成人网人人网站| 国产成人精品久久一区二区三区| 伊人久久五月天| 激情五月综合综合久久69| 久久婷婷五月综合国产尤物app| 欧美一级久久久久久久大片| 久久精品嫩草影院| 精品国产乱码久久久久久1区2区| 2019久久久高清456| 久久天天日天天操综合伊人av| 97久久精品无码一区二区 | 国产国产成人精品久久| 久久久久久国产精品无码下载| 99久久综合狠狠综合久久止| 无码人妻久久一区二区三区免费| 无码任你躁久久久久久| 久久久WWW成人免费精品| 精品免费tv久久久久久久| 久久综合九色综合网站| 综合人妻久久一区二区精品| 麻豆av久久av盛宴av| 狠狠色丁香久久婷婷综合图片| 久久人妻少妇嫩草AV蜜桃| 久久久久久久综合综合狠狠| segui久久国产精品| 久久久久亚洲av成人无码电影 | 91精品国产高清久久久久久91| 国产精品久久久久久久久免费 | 久久精品国产福利国产秒| 狠狠色丁香婷婷久久综合不卡|