Stopwatch是C#中用于精确测量代码执行时间的类,位于System.Diagnostics命名空间下,基于系统高精度性能计数器,比DateTime.Now更准确,适合性能测试和耗时分析。它通过StartNew()启动、Stop()停止,Elapsed属性获取总耗时,ElapsedMilliseconds返回毫秒数。常用方法包括Start、Stop、Reset、Restart等。为提高准确性,建议在Release模式下多次运行取平均值,并避免GC等因素干扰。示例显示了单次和多次测量的实现方式,是C#中标准的时间测量方案。
Stopwatch 是 C# 中用于精确测量代码执行时间的类,位于 System.Diagnostics 命名空间下。它基于系统高精度性能计数器,比使用 DateTime.Now 更加准确,特别适合用来做性能测试、代码段耗时分析等场景。
Stopwatch 利用系统的高分辨率性能计数器(如果可用),通过 CPU 的周期或硬件计时器来记录时间,因此精度远高于毫秒级的 DateTime。它不会受到系统时间调整(如用户修改时间、NTP 同步)的影响。
基本使用步骤如下:
示例代码:
using System; using System.Diagnostics;var stopwatch = Stopwatch.StartNew(); // 模拟一段耗时操作 for (int i = 0; i < 1000000; i++) { Math.Sqrt(i); } stopwatch.Stop();
Console.WriteLine($"耗时: {stopwatch.ElapsedMilliseconds} 毫秒"); Console.WriteLine($"更精确时间: {stopwatch.Elapsed.TotalSeconds:F6} 秒");
示例:多次测量取平均
var times = new List(); for (int i = 0; i < 10; i++) { var sw = Stopwatch.StartNew(); // 要测试的方法 MyMethod(); sw.Stop(); times.Add(sw.ElapsedMilliseconds); } double avg = times.Average(); Console.WriteLine($"平均耗时: {avg:F2} 毫秒");
基本上就这些。Stopwatch 简单高效,是 C# 中测量执行时间的标准做法。