a亚洲精品_精品国产91乱码一区二区三区_亚洲精品在线免费观看视频_欧美日韩亚洲国产综合_久久久久久久久久久成人_在线区

首頁 > 編程 > C# > 正文

C#測量程序運行時間及cpu使用時間實例方法

2020-01-24 03:04:39
字體:
供稿:網(wǎng)友

這里要指出的是, 運行一段程序,使用的cpu時間,跟實際運行的時間是不一樣的。附例如下:

復制代碼 代碼如下:

private void ShowRunTime()
  {
   TimeSpan ts1 = Process.GetCurrentProcess().TotalProcessorTime;
   Stopwatch stw = new Stopwatch();
  stw.Start();
  int Circles = 1000;
   for (int i = 0; i < Circles; ++i)
  {
  }
  double Msecs = Process.GetCurrentProcess().TotalProcessorTime.Subtract(ts1).TotalMilliseconds;
  stw.Stop();
    Console.WriteLine(string.Format("循環(huán)次數(shù):{0} CPU時間(毫秒)={1} 實際時間(毫秒)={2}", Circles, Msecs, stw.Elapsed.TotalMilliseconds, stw.ElapsedTicks));
  Console.WriteLine(string.Format("1 tick = {0}毫秒", stw.Elapsed.TotalMilliseconds / stw.Elapsed.Ticks));
 }

程序輸出如下:
循環(huán)次數(shù):1000 CPU時間(毫秒)=50.072 實際時間(毫秒)=666.9071
1 tick = 0.0001毫秒

可以看出在這個例子中,兩者差距比較大,其原因如下:

1)Windows是多任務(wù)操作系統(tǒng),按照線程為單位對cpu時間輪詢分配。即一個程序運行的中途,可能被剝奪cpu資源,供其他程序運行。
2)程序本身會有不占用cpu時間的等待過程。這個等待可能是我們程序主動的,比如啟動一個進程,然后等待進程的結(jié)束;也可能是我們沒有意識到的,如例子 的Console.WriteLine方法,猜想其內(nèi)部進行了一系列的異步I/O操作然后等待操作的完成,這其間并沒有占用調(diào)用進程的cpu時間,但耗費 了很多等待時間。
總結(jié):
1)性能的測量,應該用程序運行時間來測量,當然也需要使用cpu時間作為參考,如果兩者差距很大,需要考慮為何出現(xiàn)這種情況。
2).Net的Stopwatch類可以精確到1/10000毫秒,基本可以滿足測量精度。


個人整理
Elapsed和ElapsedMilliseconds屬性在被調(diào)用時,會在內(nèi)部調(diào)用kernel32中的QueryPerformanceFrequency()函數(shù)以獲取處理器支持的高精度計時器的頻率,隨后用這個數(shù)字對獲取的時間差值進行修正,最后Elapsed屬性會返回一個新的TimeSpan對象。而獲取ElapsedTicks屬性時則不會進行這種高精度的計算(修正)。但是一般來說這兩者的誤差并不是很大。如果需要精確計算時間或是測試數(shù)據(jù)量特別大的情況下,推薦使用Elapsed和ElapsedMilliseconds屬性。

存在疑問
我測試之后發(fā)現(xiàn)并沒有像如下所說的結(jié)論,我已經(jīng)回復原作者,暫未得到答復。希望知道原因的朋友指明下。謝謝。
從內(nèi)部實現(xiàn)來看,StopWatch.IsHighresolution = true時,StopWatch.Elapsed.Ticks應該等于StopWatch.ElapsedTicks再乘以frequency(頻率的常量)。反之,這2個數(shù)在IsRunning為true時,應該是相等的。所以照理應該是StopWatch.Elapsed.Ticks會比較大。

發(fā)表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發(fā)表
主站蜘蛛池模板: 一级黄色录像在线观看 | 国家aaa的一级看片 亚洲国产91 | 日本三级国产 | 1区2区3区视频 | 国产99久久精品 | 日韩另类| 99精品国产高清一区二区麻豆 | 在线一区视频 | 中文字幕亚洲一区 | 日本激情视频在线观看 | 亚洲一区二区三区四区在线观看 | 中文字幕在线观看第一页 | 一区二区三区视频免费观看 | 午夜精品久久久久久99热软件 | 日韩高清国产一区在线 | 狠狠色香婷婷久久亚洲精品 | 日韩成人精品 | 久久国产一区二区 | 成人黄在线观看 | 国产成人在线免费观看视频 | 日韩精品一区二区三区在线观看 | 视频一区欧美 | 午夜在线小视频 | 欧美亚洲国产精品 | 国产黄色在线观看 | 成人欧美一区二区三区黑人麻豆 | 成人在线免费小视频 | 自拍偷拍亚洲视频 | 综合精品久久久 | 亚洲精品视频一区 | 久久久久久久亚洲精品 | 青青青免费视频在线 | 99色在线视频 | 四虎最新影视 | 中文字幕在线免费 | 成人免费在线电影 | 国产成人a v | 最新日韩精品在线观看 | 免费超碰 | 亚洲免费片 | 先锋资源久久 |