如果你擔憂某些代碼非常耗費時間,可以用StopWatch來檢查這段代碼消耗的時間,如下面的代碼所示
System.Diagnostics.Stopwatch timer = new System.Diagnostics.Stopwatch();timer.Start();Decimal total = 0;int limit = 1000000;for (int i = 0; i < limit; ++i){ total = total + (Decimal)Math.Sqrt(i);}timer.Stop();Console.WriteLine(“Sum of sqrts: {0}”,total);Console.WriteLine(“Elapsed milliseconds: {0}”,timer.ElapsedMilliseconds);Console.WriteLine(“Elapsed time: {0}”, timer.Elapsed);
現在已經有專門的工具來檢測程式的已耗用時間,可以細化到每個方法,比如dotNetPerformance軟體。
以上面的代碼為例子,您需要直接修改原始碼,如果是用來測試程式,則有些不方便。請參考下面的例子。
class AutoStopwatch : System.Diagnostics.Stopwatch, IDisposable{ public AutoStopwatch() { Start(); } public void Dispose() { Stop(); Console.WriteLine(“Elapsed: {0}”, this.Elapsed); }}
藉助於using文法,像下面的代碼所示,可以檢查一段代碼的已耗用時間,並列印在控制台上。
using (new AutoStopwatch()){ Decimal total2 = 0; int limit2 = 1000000; for (int i = 0; i < limit2; ++i) { total2 = total2 + (Decimal)Math.Sqrt(i); }}