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

            1.  Trace Log 

            這個(gè)是大家最常用,也是最簡(jiǎn)單和有效地方法。通常是在函數(shù)的開(kāi)始和結(jié)束的位置加入Log, 最后通過(guò)Log記錄時(shí)間統(tǒng)計(jì)函數(shù)的時(shí)間消耗。
            有時(shí)嫌2次log太麻煩,我們可以通過(guò)RAII進(jìn)行封裝:
            class CTimeCostDebug
            {
            public:
             CTimeCostDebug(LPCTSTR lpszFunName);
             
            ~CTimeCostDebug()
            };

            我們?cè)跇?gòu)造函數(shù)里記錄開(kāi)始時(shí)間,在析構(gòu)函數(shù)里記錄結(jié)束時(shí)間以及打印時(shí)間消耗。

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


                
            return 0;
            }

            這里時(shí)間記錄函數(shù)推薦用高精度的QueryPerformanceCounter (曾經(jīng)嘗試用GetTickCount,結(jié)果發(fā)現(xiàn)誤差超過(guò)10ms).

            2. WinDbg的!runaway命令

            該命令可以打印每個(gè)線程的時(shí)間消耗:包括用戶模式執(zhí)行時(shí)間,內(nèi)核模式執(zhí)行時(shí)間以及線程創(chuàng)建到現(xiàn)在的總時(shí)間。
            通過(guò)該命令我們可以分析出哪些線程在空轉(zhuǎn)消耗時(shí)間,然后進(jìn)行優(yōu)化


            3. WinDbg 的 wt 命令

            該命令可以幫我們分析目標(biāo)函數(shù)及其子程序執(zhí)行的指令數(shù),然后幫我們分析該函數(shù)的性能消耗分布。
            比如我們分析ShowWindow API 的指令消耗, 我們可以看到內(nèi)部子函數(shù)的調(diào)用及開(kāi)銷:



            4. VS  profiler

            VS  2010之后自帶性能分析工具Profiler, 該工具可以幫我們對(duì)程序運(yùn)行的性能進(jìn)行分析。



            5.  Intel VTune

            我用的是  Intel VTune Amplifier XE 2011, 這個(gè)工具非常專業(yè),可以在VS2008里使用,幫我們分析程序的熱點(diǎn)開(kāi)銷和關(guān)鍵調(diào)用。





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

            FeedBack:
            # re: 如何分析程序的時(shí)間消耗
            2014-11-28 17:21 | prog
            還可以用xperf  回復(fù)  更多評(píng)論
              
            # re: 如何分析程序的時(shí)間消耗[未登錄](méi)
            2015-04-07 19:24 |
            你有關(guān)于一個(gè)軟件中哪些代碼耗時(shí)估算的論文嗎,有給我發(fā)一些,1427809344,謝謝  回復(fù)  更多評(píng)論
              
            青青草原综合久久大伊人| 欧美日韩精品久久久久| 天天爽天天狠久久久综合麻豆| 久久精品人人做人人爽电影| 色欲久久久天天天综合网| 99久久免费国产特黄| 久久97久久97精品免视看| 久久九九兔免费精品6| 99国产精品久久| 久久伊人影视| 久久96国产精品久久久| 久久国产美女免费观看精品| 亚洲国产美女精品久久久久∴| 精品久久久久久无码中文野结衣| 久久久久久综合网天天| 精品久久久久国产免费| 精品久久久久久无码专区| 久久精品国产99国产精品| 狠狠狠色丁香婷婷综合久久五月| 国产精品亚洲综合久久| 91亚洲国产成人久久精品| 久久久一本精品99久久精品88| 亚洲国产天堂久久久久久| 国产精品一区二区久久精品无码| 亚洲日韩中文无码久久| 亚洲精品国产自在久久| 狠狠综合久久综合中文88| 久久精品免费观看| 成人国内精品久久久久影院| 久久亚洲日韩精品一区二区三区| 日韩亚洲国产综合久久久| 国产精品xxxx国产喷水亚洲国产精品无码久久一区 | 欧美久久久久久午夜精品| 久久777国产线看观看精品| 91久久婷婷国产综合精品青草 | 精品久久久久久久久中文字幕| 亚洲午夜久久久久久久久电影网 | 91精品婷婷国产综合久久 | 色88久久久久高潮综合影院| 久久人人爽人人爽人人片AV不 | 国产精品久久一区二区三区|