總結(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