C#测量程序运行时间及cpu使用时间(转)
?? 對一個服務(wù)器程序想統(tǒng)計每秒可以處理多少數(shù)據(jù)包,要如何做?答案是用處理數(shù)據(jù)包的總數(shù),除以累記處理數(shù)據(jù)包用的時間。這里要指出的是, 運行一段程序,使用的cpu時間,跟實際運行的時間是不一樣的。附例如下:
????
???? 程序輸出如下:
???? 循環(huán)次數(shù):1000 CPU時間(毫秒)=50.072 實際時間(毫秒)=666.9071
???? 1 tick = 0.0001毫秒
???? 可以看出在這個例子中,兩者差距比較大,其原因如下:
???? 1)Windows是多任務(wù)操作系統(tǒng),按照線程為單位對cpu時間輪詢分配。即一個程序運行的中途,可能被剝奪cpu資源,供其他程序運行。
???? 2)程序本身會有不占用cpu時間的等待過程。這個等待可能是我們程序主動的,比如啟動一個進(jìn)程,然后等待進(jìn)程的結(jié)束;也可能是我們沒有意識到的,如例子 的Console.WriteLine方法,猜想其內(nèi)部進(jìn)行了一系列的異步I/O操作然后等待操作的完成,這其間并沒有占用調(diào)用進(jìn)程的cpu時間,但耗費 了很多等待時間。
???? 總結(jié):
???? 1)性能的測量,應(yīng)該用程序運行時間來測量,當(dāng)然也需要使用cpu時間作為參考,如果兩者差距很大,需要考慮為何出現(xiàn)這種情況。
???? 2).Net的Stopwatch類可以精確到1/10000毫秒,基本可以滿足測量精度。
轉(zhuǎn)載于:https://www.cnblogs.com/yanpeng/archive/2008/10/15/1943369.html
總結(jié)
以上是生活随笔為你收集整理的C#测量程序运行时间及cpu使用时间(转)的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。
- 上一篇: VDI序曲二十七 IE7,IE8,IE9
- 下一篇: .NET中栈和堆的比较【转自:c#开发园