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

            戰(zhàn)魂小筑

            討論群:309800774 知乎關(guān)注:http://zhihu.com/people/sunicdavy 開源項(xiàng)目:https://github.com/davyxu

               :: 首頁(yè) :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理 ::
              257 隨筆 :: 0 文章 :: 506 評(píng)論 :: 0 Trackbacks

            測(cè)試環(huán)境:Visual Studio 2008 SP1

            測(cè)試對(duì)象:RTTI的dynamic_cast和自己實(shí)現(xiàn)的RTTI系統(tǒng),代碼如下

                    template<typename TClass>
                    TClass* Cast( )
                    {
                        return IsKindOf( TClass::StaticGetClassInfo() ) ? (TClass*)this:null;
                    }

             

                bool RTTIObject::IsKindOf( RTTIClass* ClassInfo )
                {
                    RTTIClass* ThisClass = GetRTTIClass();
             
                    if ( ThisClass == null )
                        return false;
                    
                    return ThisClass->IsKindOf( ClassInfo );
                }

             

                bool RTTIClass::IsKindOf( RTTIClass* ClassInfo )
                {
                    RTTIClass* ThisClass = this;
                    while ( ThisClass != null )
                    {
                        if ( ClassInfo == ThisClass )
                            return true;
             
                        ThisClass = ThisClass->mParentClass;
                    }
             
                    return false;
                }

             

            測(cè)試代碼:

            class ClassA : public RTTIObject
            {
            public:
            DECLARE_RTTI_CLASS( ClassA )
            int a;
            private:
            };
            IMPLEMENT_RTTIROOT( ClassA )
             
            class ClassB: public ClassA
            {
                DECLARE_RTTI_CLASS( ClassB )
            public:
            int b;
            private:
            };
            IMPLEMENT_RTTI_CLASS( ClassB, ClassA )
             
            class ClassC : public ClassB
            {
                DECLARE_RTTI_CLASS( ClassC )
            public:
            int c;
            private:
            };
            IMPLEMENT_RTTI_CLASS( ClassC, ClassB )
             
            class ClassD: public ClassA
            {
                DECLARE_RTTI_CLASS( ClassD )
            public:
            int d;
            private:
            };

                ClassC c;
                ClassD d;
                
                ClassA* fakeC = &c;
                ClassA* fakeD = &d;
             
                const int TestTimes = 10000;
             
                float t1 = TimeSource::GetAppTime();
             
                for ( int i = 0;i<TestTimes;i++)
                {
                    ClassC* realC = dynamic_cast<ClassC*>(fakeC);
                    ClassD* realD = dynamic_cast<ClassD*>(fakeD);
                }
             
                float t2 = TimeSource::GetAppTime() - t1;
             
                for ( int i = 0;i<TestTimes;i++)
                {
                    ClassC* realC = fakeC->Cast<ClassC>( );
                    ClassD* realD = fakeD->Cast<ClassD>( );
                }
             
                float t3 = TimeSource::GetAppTime() - t2;
             
                SimpleLog log;
                log.Debug(L"%f  %f", t2, t3);

             

            10000次,單位:毫秒   dynamic_cast     Cast
                    Debug 1.468590 5.173067
                    Release 1.025950 0.702404

             

            可以看得出來(lái),沒(méi)有優(yōu)化過(guò)的Cast代碼性能極差,但是優(yōu)化過(guò)的Cast性能超越了系統(tǒng)的dynamic_cast,跟蹤匯編發(fā)現(xiàn)系統(tǒng)有做個(gè)一些異常及bad_cast的處理

            建議:可以做一個(gè)宏,在不支持RTTI的編譯器及平臺(tái)下使用自己的Cast


            評(píng)論

            # re: VC的RTTI系統(tǒng)性能測(cè)試 2010-12-05 09:44 Condor
            代碼不完整。  回復(fù)  更多評(píng)論
              

            青青草原综合久久| 无码精品久久一区二区三区| 欧美牲交A欧牲交aⅴ久久| 久久久久av无码免费网| 久久久久久亚洲AV无码专区| 久久久久久毛片免费播放| 狠狠狠色丁香婷婷综合久久五月| 国产成人久久精品麻豆一区| 欧美精品乱码99久久蜜桃| 色婷婷久久综合中文久久蜜桃av| 久久99精品久久久久久动态图| 狠狠色综合久久久久尤物| 日韩人妻无码精品久久免费一| 9191精品国产免费久久| 精品人妻伦九区久久AAA片69| 久久精品人人做人人爽电影| 国内精品伊人久久久影院| 日本免费一区二区久久人人澡 | 久久99精品久久久久久噜噜| 狠狠色婷婷久久综合频道日韩| 青青青伊人色综合久久| 久久人人爽人人爽人人AV东京热| 国产精品久久久天天影视香蕉 | 99久久成人国产精品免费| 久久久精品国产亚洲成人满18免费网站| 亚洲精品乱码久久久久久蜜桃不卡 | 亚洲精品tv久久久久| 久久久WWW成人| 精品国产一区二区三区久久蜜臀| 人妻精品久久久久中文字幕一冢本| 久久精品人妻一区二区三区| 99国产欧美精品久久久蜜芽 | 7777精品久久久大香线蕉| 亚洲第一永久AV网站久久精品男人的天堂AV | 久久96国产精品久久久| 久久久久久久精品成人热色戒 | 无码乱码观看精品久久| 久久亚洲高清综合| 亚洲国产成人久久精品99| 久久国产美女免费观看精品 | 无夜精品久久久久久|