• <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 開(kāi)源項(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)論
              

            精品999久久久久久中文字幕| 亚洲AV无码久久精品色欲| 久久综合亚洲色HEZYO社区| 精品久久香蕉国产线看观看亚洲| 欧美激情精品久久久久久久| 久久久亚洲精品蜜桃臀| 亚洲综合婷婷久久| 久久久久99精品成人片牛牛影视| 亚洲欧美日韩精品久久| 久久精品视频免费| 曰曰摸天天摸人人看久久久| 精品久久一区二区三区| 国内精品久久久久久久久电影网| 久久无码精品一区二区三区| 亚洲第一永久AV网站久久精品男人的天堂AV | 51久久夜色精品国产| 亚洲AV无一区二区三区久久| 欧美精品九九99久久在观看| 亚洲AV无码久久精品狠狠爱浪潮| 狠狠色婷婷久久综合频道日韩| 久久不射电影网| 狠狠久久综合| 国内精品久久久久影院老司| 亚洲AV无码1区2区久久 | 国产成人精品三上悠亚久久| 亚洲国产欧洲综合997久久| 精品久久久无码人妻中文字幕豆芽 | 国内精品久久久久久久影视麻豆 | 久久青青色综合| 蜜臀av性久久久久蜜臀aⅴ| 精品久久久久久无码中文字幕| 污污内射久久一区二区欧美日韩| 777午夜精品久久av蜜臀| 91精品国产色综合久久| 久久人人爽人人人人爽AV| 国产精品免费久久久久久久久| 狠狠干狠狠久久| 亚洲人AV永久一区二区三区久久 | 久久国产成人午夜aⅴ影院 | 免费观看久久精彩视频| 国内精品久久久久久99蜜桃|