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

            国产aⅴ激情无码久久| 亚洲人AV永久一区二区三区久久| 久久久久无码中| 欧美午夜A∨大片久久| 欧美一区二区久久精品| 久久久久亚洲av无码专区导航| 热re99久久6国产精品免费| www.久久热.com| 亚洲国产香蕉人人爽成AV片久久 | 狠狠色丁香婷婷久久综合| 精品久久久久久无码不卡| 99久久精品影院老鸭窝| 久久人人爽人人澡人人高潮AV| 亚洲成色www久久网站夜月| 日韩精品久久久久久| 亚洲愉拍99热成人精品热久久| 岛国搬运www久久| 亚洲精品无码久久久久sm| 久久天天躁狠狠躁夜夜不卡 | 久久久久久免费一区二区三区| 久久九九免费高清视频| 99久久99久久| 午夜天堂av天堂久久久| 色狠狠久久综合网| 国产激情久久久久影院小草| 国产精品9999久久久久| 精品多毛少妇人妻AV免费久久| 久久久中文字幕日本| 国产成人精品久久亚洲高清不卡 | 色欲久久久天天天综合网| 久久精品无码一区二区三区免费 | 国产精品久久久久久影院| 99久久精品国产一区二区 | 久久综合久久自在自线精品自 | 亚洲日本va午夜中文字幕久久 | 免费无码国产欧美久久18| 久久国产乱子伦精品免费午夜| 久久久久一区二区三区| 久久久久国产一级毛片高清版| 精品无码久久久久久尤物| 亚洲AV日韩精品久久久久久|