最近關注程序性能的優化方面,本想寫篇CLRProfiler的簡要文檔,看到pengpeng已寫好,那就轉載好了,偷偷懶。html
也有不足之處:
1.減緩運行速度,結果不能代表程序的速度
2.不能附加到進程
3.他由於記錄了不少內容,若是記錄了很長的時間,分析的過程將會好久
4.也就是這個東西,只好用來測試環境,生產環境就得Windbg了api
先給張運行截圖,在下面說面各類功能。多線程
這是工具的祝界面,start application 選擇須要運行的程序,能夠選擇是否跟蹤內存分配和方法調用。當關閉應用程序(能夠自動或手動),Profiler自動開始整理結果。顯示以下:app
在這裏顯示本次統計中的彙總。asp.net
Clr Profiler有個抓Dump的功能,固然是及時性的,在程序運行時點擊show head now 便可抓取Dump同時很快的統計處分析結果。工具
以下:post
在統計界面上有不少查看詳情的按鈕:性能
heap statistic 堆棧對象信息統計測試
Allocated :應用程序整個啓動週期內分配的對象,按照對象大小排列,不一樣的顏色代碼不一樣的對象,這在右側會列出,沒有截出來,下面的也是這樣:優化
Relocated:從新移動過的對象,GC以後內存整理移動過的對象:
Finally head 最終堆棧內對象信息:
還有object finalized 和 critical object finalized,表示被終止化器終止的對象,後面那個是特殊標記過的終止對象,圖相差不大就沒有截取了。
接下來的就是垃圾回收統計
這個歸總了回收次數
TimeLine:這是詳細圖(貌似這個得較強的顯卡渲染,在公司那機器就出不來)
圖中能夠清晰的看出各次回收時間和先後內存佔用量
GC Handle 統計GC句柄數
具體細節以下:
其餘
summery界面沒有顯示全部的功能:
在View下面能夠找到這些:
在全部的柱形圖上右鍵有以下菜單,show who allocated Is a nice one,經過他能夠追蹤對象是誰分配的。
assmebly graph
class graph
call tree 這個功能記錄每一個方法的調用次數,感受仍是vs自帶分析好些,那個還能統計時間佔用:)
和進哥提及這個CLR Profiler,說回去寫篇使用說明發出來。終於寫好了,寫篇還真花時間,這回真的理解live writer的好用,若是在網頁裏面編輯真要死人了。
這是對CLR Profiler介紹性的文章,具體應用場景在看完應該也能想到。限於篇幅,不少內容沒有寫出來,在卸載clr profiler中會帶有詳細的說明,100多頁,真的很詳細,有了它就不必再去查什麼資料了。建議不明白的仍是看看那個爲好:)
轉自:http://www.cnblogs.com/lulu/archive/2010/08/21/1805444.html