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

             

            可以看得出來,沒有優(yōu)化過的Cast代碼性能極差,但是優(yōu)化過的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)論
              

            一日本道伊人久久综合影| 日韩av无码久久精品免费| 久久99九九国产免费看小说| 一本久久a久久精品vr综合| 国产精品久久久久无码av| 久久高清一级毛片| 1000部精品久久久久久久久| 国产99久久九九精品无码| 97视频久久久| 久久中文精品无码中文字幕| 99久久人妻无码精品系列| 午夜精品久久久久久影视777| 色欲av伊人久久大香线蕉影院 | 久久r热这里有精品视频| 一级女性全黄久久生活片免费| 久久66热人妻偷产精品9| 亚洲欧美日韩中文久久| 亚洲国产成人久久精品99 | 久久亚洲国产精品一区二区| 亚洲精品国产第一综合99久久| 精品精品国产自在久久高清| 久久精品中文无码资源站| 区久久AAA片69亚洲 | 国产91久久精品一区二区| 亚洲乱码中文字幕久久孕妇黑人| 色99久久久久高潮综合影院| 久久午夜福利电影| 久久免费99精品国产自在现线 | 精品伊人久久久| 亚洲日本久久久午夜精品| 一本大道久久香蕉成人网| 人妻中文久久久久| 亚洲人成无码www久久久| 无码精品久久一区二区三区| 欧洲性大片xxxxx久久久| 香蕉久久影院| 亚洲精品乱码久久久久久蜜桃不卡| 亚洲国产精品无码成人片久久| 久久青青草原精品国产| 成人综合伊人五月婷久久| 情人伊人久久综合亚洲|