• <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 空明流轉 閱讀(1497) 評論(0)  編輯 收藏 引用
            亚洲午夜久久久| 久久高清一级毛片| 欧美丰满熟妇BBB久久久| 日日噜噜夜夜狠狠久久丁香五月| 欧美一区二区三区久久综| 亚洲国产精品久久久天堂 | 高清免费久久午夜精品| 久久99热国产这有精品| 久久久午夜精品| 久久精品国产影库免费看| 久久久久久久免费视频| 国产AⅤ精品一区二区三区久久 | 久久亚洲国产成人影院网站 | 久久国产精品免费一区| 无码AV中文字幕久久专区| 国产免费久久久久久无码| 久久精品国产第一区二区三区| 国产精品99久久久久久猫咪| 久久久久免费看成人影片| 波多野结衣久久一区二区| 精品久久久久久无码人妻蜜桃| 久久精品国产亚洲av影院| 99久久精品免费看国产一区二区三区 | 久久久久精品国产亚洲AV无码| 99久久精品国产毛片| 久久ww精品w免费人成| 久久人人爽人人爽人人片av高请| 久久99国产精品久久99小说| 久久精品国产国产精品四凭| 高清免费久久午夜精品| 国产亚洲色婷婷久久99精品| 亚洲人成精品久久久久| 久久亚洲精品无码aⅴ大香 | 久久亚洲精品成人av无码网站| 国产精品99久久久精品无码| 久久亚洲高清综合| 日产久久强奸免费的看| 亚洲欧洲中文日韩久久AV乱码| 久久最新免费视频| 欧美精品乱码99久久蜜桃| 久久99精品国产麻豆宅宅|