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

            歲月流轉,往昔空明

            C++博客 首頁 新隨筆 聯系 聚合 管理
              118 Posts :: 3 Stories :: 413 Comments :: 0 Trackbacks

             

            struct Timer{
                
            void GetTime(__int64* ptime)
                
            {
                    
            //QueryPerformanceCounter((LARGE_INTEGER*)ptime);
                    __asm
                    
            {
                        push edx;
                        push ecx;
                        mov ecx,ptime;
                        rdtsc
                            mov [ecx],eax;
                        mov [ecx
            +4],edx;
                        pop ecx;
                        pop edx;
                    }

                }

            }
            ;

            Timer g_timer;

            struct ProfilerSample
            {
                __int64 begin;
                __int64 end;
                __int64 count;
                __int64 total;

                ProfilerSample() : begin(
            0), end(0), count(0), total(0)
                
            {}

                
            void Reset() {
                    begin 
            = end = count = total = 0;
                }


                
            void Begin() {
                    g_timer.GetTime(
            &begin);
                }


                
            void End() {
                    g_timer.GetTime(
            &end);
                    total 
            += (end - begin);
                }

            }
            ;

            class ProfilerNode
            {
            public:
                ProfilerNode
            * m_parent;
                ProfilerNode
            * m_son;
                ProfilerNode
            * m_sibling;

                
            const char* m_profName;

                ProfilerSample m_sample;

            public:
                ProfilerNode(
            const char* name, ProfilerNode* parent);
                
            ~ProfilerNode();

                
            void Begin();
                
            void End();

                
            const char* GetName();
                
            const ProfilerSample* GetProfSample();

                ProfilerNode
            * GetSon(const char* str);
                ProfilerNode
            * GetDirectSon();
                ProfilerNode
            * GetNextSibling();
                ProfilerNode
            * GetParent();
            }
            ;

            ProfilerNode::ProfilerNode(
            const char* name, ProfilerNode* parent)
                : m_profName(name), m_parent(parent), m_son(NULL), m_sibling(NULL)
            {
            }


            ProfilerNode::
            ~ProfilerNode()
            {
                delete m_son;
                delete m_sibling;
            }


            const char* ProfilerNode::GetName()
            {
                
            return m_profName;
            }


            const ProfilerSample* ProfilerNode::GetProfSample()
            {
                
            return &m_sample;
            }


            //獲取一個兒子
            ProfilerNode* ProfilerNode::GetSon(const char* str)
            {
                ProfilerNode
            * p = m_son;

                
            while(p != NULL) {
                    
            if(p->m_profName == str) {
                        
            break;
                    }

                    p 
            = p->GetNextSibling();
                }


                
            if(p == NULL)
                
            {
                    p 
            = new ProfilerNode(str, this);
                    p
            ->m_sibling = m_son;
                    m_son 
            = p;
                }


                
            return p;
            }


            //獲取一個兒子
            ProfilerNode* ProfilerNode::GetDirectSon()
            {
                
            return m_son;
            }


            ProfilerNode
            * ProfilerNode::GetNextSibling()
            {
                
            return m_sibling;
            }


            ProfilerNode
            * ProfilerNode::GetParent()
            {
                
            return m_parent;
            }


            void ProfilerNode::Begin()
            {
                m_sample.Begin();
            }


            void ProfilerNode::End()
            {
                m_sample.End();
            }


            //性能分析管理器
            //注意初始化順序!
            class ProfilerManager
            {
            private:
                ProfilerManager() : root(
            "root", NULL), m_curProfNode(&root){}
                ProfilerManager(
            const ProfilerManager& rhs);
                ProfilerManager
            &  operator = (const ProfilerManager& rhs);

                
            static ProfilerManager s_profmgr;

            private:
                ProfilerNode root;
                ProfilerNode
            * m_curProfNode;

            public:
                
            static ProfilerManager& Instance() {
                    
            return s_profmgr;
                }


                
            void BeginProfiler(const char* name);
                
            void EndProfiler();

                ProfilerNode
            * GetRootProfilerNode() {
                    
            return &root;
                }

            }
            ;

            ProfilerManager ProfilerManager::s_profmgr;

            void ProfilerManager::BeginProfiler(const char* name)
            {
                m_curProfNode 
            = m_curProfNode->GetSon(name);
                m_curProfNode
            ->Begin();
            }


            void ProfilerManager::EndProfiler()
            {
                m_curProfNode
            ->End();
                m_curProfNode 
            = m_curProfNode->GetParent();
            }


            class Profiler
            {
            public:
                Profiler(
            const char* name)
                
            {
                    ProfilerManager::Instance().BeginProfiler(name);
                }

                
            ~Profiler()
                
            {
                    ProfilerManager::Instance().EndProfiler();
                }

            }
            ;

            #define BEGIN_PROF(name) ProfilerManager::Instance().BeginProfiler(name);
            #define END_PROF(name) ProfilerManager::Instance().EndProfiler();

            LARGE_INTEGER j;

            void OutputProf(ProfilerNode* p, int space = 0)
            {
                ProfilerNode
            * tmp;

                
            const ProfilerSample* ps = p->GetProfSample();
                
            for(int i = 0; i < space; ++i) {
                    cout 
            << " ";
                }

                cout 
            << p->GetName() << ": 調用次數: " << ps->count << " 調用總耗時: " << ps->total << endl;

                
            if(tmp = p->GetDirectSon()) {
                    OutputProf(tmp, space
            +1);
                }
             else {
                    
            if(tmp = p->GetNextSibling()) {
                        OutputProf(tmp, space);
                    }

                }

            }
            posted on 2005-11-30 11:32 空明流轉 閱讀(1496) 評論(0)  編輯 收藏 引用
            青青草国产精品久久| 精产国品久久一二三产区区别| 香港aa三级久久三级老师2021国产三级精品三级在 | 久久亚洲精品无码aⅴ大香| 久久国产视屏| 日日狠狠久久偷偷色综合免费 | 九九久久99综合一区二区| 亚洲av伊人久久综合密臀性色| 久久精品无码一区二区WWW| 久久精品国产精品亚洲精品| 久久久久久久久66精品片| 久久中文字幕人妻丝袜| 久久人人爽爽爽人久久久| 精品久久久久久亚洲| 久久99精品免费一区二区| 一级女性全黄久久生活片免费| 污污内射久久一区二区欧美日韩| 色8激情欧美成人久久综合电| 中文字幕无码av激情不卡久久| 99精品国产免费久久久久久下载| 久久久久久精品成人免费图片| 色88久久久久高潮综合影院| 国产精品久久久久aaaa| 91亚洲国产成人久久精品| 亚洲精品乱码久久久久久不卡| 久久精品国产99国产精品导航| 精品国产乱码久久久久久1区2区| 一本色道久久88加勒比—综合| 久久免费大片| 国产午夜久久影院| 无码人妻久久一区二区三区蜜桃| 久久成人国产精品| 久久久综合香蕉尹人综合网| 无码AV波多野结衣久久| 国产巨作麻豆欧美亚洲综合久久| 久久精品亚洲AV久久久无码| 丁香五月综合久久激情| 亚洲va中文字幕无码久久| 久久精品夜色噜噜亚洲A∨| 青青草原精品99久久精品66| 亚洲精品成人久久久|