• <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>
            總結一些常用的方法,思考如何分析一個程序的時間消耗。

            1.  Trace Log 

            這個是大家最常用,也是最簡單和有效地方法。通常是在函數的開始和結束的位置加入Log, 最后通過Log記錄時間統計函數的時間消耗。
            有時嫌2次log太麻煩,我們可以通過RAII進行封裝:
            class CTimeCostDebug
            {
            public:
             CTimeCostDebug(LPCTSTR lpszFunName);
             
            ~CTimeCostDebug()
            };

            我們在構造函數里記錄開始時間,在析構函數里記錄結束時間以及打印時間消耗。

            只要這樣用就好了:
            int main()
            {
                {
                    CTimeCostDebug t(_T("test_fun"));
                    test_fun();
                }


                
            return 0;
            }

            這里時間記錄函數推薦用高精度的QueryPerformanceCounter (曾經嘗試用GetTickCount,結果發現誤差超過10ms).

            2. WinDbg的!runaway命令

            該命令可以打印每個線程的時間消耗:包括用戶模式執行時間,內核模式執行時間以及線程創建到現在的總時間。
            通過該命令我們可以分析出哪些線程在空轉消耗時間,然后進行優化


            3. WinDbg 的 wt 命令

            該命令可以幫我們分析目標函數及其子程序執行的指令數,然后幫我們分析該函數的性能消耗分布。
            比如我們分析ShowWindow API 的指令消耗, 我們可以看到內部子函數的調用及開銷:



            4. VS  profiler

            VS  2010之后自帶性能分析工具Profiler, 該工具可以幫我們對程序運行的性能進行分析。



            5.  Intel VTune

            我用的是  Intel VTune Amplifier XE 2011, 這個工具非常專業,可以在VS2008里使用,幫我們分析程序的熱點開銷和關鍵調用。





            總之,根據二八定律,程序運行過程中20%的代碼消耗了80%的時間, 關鍵的問題是找出這20%代碼,然后進行優化。不知道大家還有沒有其他好的性能分析方法?
            posted on 2014-09-16 23:37 Richard Wei 閱讀(7884) 評論(2)  編輯 收藏 引用 所屬分類: Tool

            FeedBack:
            # re: 如何分析程序的時間消耗
            2014-11-28 17:21 | prog
            還可以用xperf  回復  更多評論
              
            # re: 如何分析程序的時間消耗[未登錄]
            2015-04-07 19:24 |
            你有關于一個軟件中哪些代碼耗時估算的論文嗎,有給我發一些,1427809344,謝謝  回復  更多評論
              
            一本久久a久久精品vr综合| 久久久久久极精品久久久| 久久婷婷色综合一区二区| 久久国产高潮流白浆免费观看| 99久久伊人精品综合观看| 2021国产精品午夜久久| 久久精品国产精品亚洲人人 | 91精品国产乱码久久久久久| 无码任你躁久久久久久老妇| 久久91综合国产91久久精品| 日韩人妻无码一区二区三区久久 | 综合人妻久久一区二区精品 | 人人狠狠综合久久亚洲88| 久久久久久久女国产乱让韩| 99精品国产在热久久| 国产精品久久久久久久久久影院| 久久国产色AV免费观看| 香蕉aa三级久久毛片| 狠狠久久亚洲欧美专区 | 亚洲色欲久久久综合网| 热久久国产精品| 久久A级毛片免费观看| 久久人妻AV中文字幕| 久久精品成人免费国产片小草| 久久66热人妻偷产精品9| 2021精品国产综合久久| 亚洲va久久久噜噜噜久久天堂| 精品伊人久久大线蕉色首页| 久久av免费天堂小草播放| 久久这里只精品99re66| 亚洲色欲久久久综合网| 久久无码AV中文出轨人妻| 久久人妻少妇嫩草AV蜜桃| 久久久久久久女国产乱让韩| 亚洲国产小视频精品久久久三级| 久久这里只有精品首页| 色综合合久久天天给综看| 亚洲精品97久久中文字幕无码| 久久99热这里只频精品6| 久久久久久免费视频| 国产亚洲精久久久久久无码77777 国产亚洲精品久久久久秋霞 |