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

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

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

            測試對象: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;
                }

             

            測試代碼:

            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)有做個一些異常及bad_cast的處理

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

            posted on 2010-10-22 16:00 戰(zhàn)魂小筑 閱讀(1314) 評論(1)  編輯 收藏 引用 所屬分類: 游戲開發(fā)技術(shù)C++/ 編程語言

            評論

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

            伊人久久综合成人网| 久久久久亚洲精品男人的天堂| 国产叼嘿久久精品久久| 婷婷五月深深久久精品| 国产毛片欧美毛片久久久| 久久久久高潮综合影院| 亚洲中文字幕无码久久综合网| 午夜视频久久久久一区| 久久人妻少妇嫩草AV无码蜜桃| 久久久九九有精品国产| 久久国产精品国产自线拍免费| 国产午夜免费高清久久影院| 69国产成人综合久久精品| 国产精品久久国产精麻豆99网站| 久久久精品2019免费观看| 99精品久久精品一区二区| 97久久超碰国产精品旧版| 久久免费高清视频| 久久一本综合| 精品久久人人爽天天玩人人妻| 国产成人精品综合久久久久| 久久99国内精品自在现线| 亚洲国产精品久久| 思思久久99热只有频精品66| 亚洲国产另类久久久精品小说| 狠色狠色狠狠色综合久久| 久久久久国产精品三级网| 久久国产色av免费看| 国产精品久久成人影院| 日韩美女18网站久久精品| 日韩乱码人妻无码中文字幕久久| 久久精品国产99国产电影网| 久久亚洲色一区二区三区| 五月丁香综合激情六月久久| 国产日韩久久久精品影院首页| 中文精品久久久久人妻不卡| 伊人久久大香线焦综合四虎| 国产A三级久久精品| 久久久久久国产精品免费免费| 久久亚洲精品人成综合网| 亚洲伊人久久综合中文成人网|