C#的Stopwatch类是什么?如何精确地测量代码执行时间?

月夜之吻
发布: 2025-11-15 09:27:25
原创
169人浏览过
Stopwatch是C#中用于精确测量代码执行时间的类,位于System.Diagnostics命名空间下,基于系统高精度性能计数器,比DateTime.Now更准确,适合性能测试和耗时分析。它通过StartNew()启动、Stop()停止,Elapsed属性获取总耗时,ElapsedMilliseconds返回毫秒数。常用方法包括Start、Stop、Reset、Restart等。为提高准确性,建议在Release模式下多次运行取平均值,并避免GC等因素干扰。示例显示了单次和多次测量的实现方式,是C#中标准的时间测量方案。

c#的stopwatch类是什么?如何精确地测量代码执行时间?

Stopwatch 是 C# 中用于精确测量代码执行时间的类,位于 System.Diagnostics 命名空间下。它基于系统高精度性能计数器,比使用 DateTime.Now 更加准确,特别适合用来做性能测试、代码段耗时分析等场景。

Stopwatch 的工作原理

Stopwatch 利用系统的高分辨率性能计数器(如果可用),通过 CPU 的周期或硬件计时器来记录时间,因此精度远高于毫秒级的 DateTime。它不会受到系统时间调整(如用户修改时间、NTP 同步)的影响。

如何使用 Stopwatch 测量代码执行时间

基本使用步骤如下:

  • 调用 Stopwatch.StartNew() 创建并启动计时器
  • 运行要测量的代码
  • 调用 Stopwatch.Stop() 停止计时
  • 通过 Elapsed 属性获取总耗时(TimeSpan 类型)

示例代码:

代码小浣熊
代码小浣熊

代码小浣熊是基于商汤大语言模型的软件智能研发助手,覆盖软件需求分析、架构设计、代码编写、软件测试等环节

代码小浣熊 51
查看详情 代码小浣熊
using System;
using System.Diagnostics;
<p>var stopwatch = Stopwatch.StartNew();
// 模拟一段耗时操作
for (int i = 0; i < 1000000; i++)
{
Math.Sqrt(i);
}
stopwatch.Stop();</p><p>Console.WriteLine($"耗时: {stopwatch.ElapsedMilliseconds} 毫秒");
Console.WriteLine($"更精确时间: {stopwatch.Elapsed.TotalSeconds:F6} 秒");</p>
登录后复制

常用属性和方法

  • Start() / Stop():手动控制启停
  • Reset():重置计时器(时间归零)
  • Restart():重置并重新开始
  • Elapsed:返回 TimeSpan,表示总耗时
  • ElapsedMilliseconds:以 long 返回毫秒数
  • ElapsedTicks:返回计时器滴答数(不是 DateTime 的 Ticks)

提高测量准确性的小技巧

  • 多次运行取平均值,避免单次测量受 GC、系统调度等干扰
  • 在 Release 模式下测试,Debug 模式会影响性能
  • 避免在测量期间进行无关操作(如打印日志)
  • 可配合 GC.Collect() 和 GC.WaitForPendingFinalizers() 预先清理垃圾,减少干扰

示例:多次测量取平均

var times = new List<long>();
for (int i = 0; i < 10; i++)
{
    var sw = Stopwatch.StartNew();
    // 要测试的方法
    MyMethod();
    sw.Stop();
    times.Add(sw.ElapsedMilliseconds);
}
<p>double avg = times.Average();
Console.WriteLine($"平均耗时: {avg:F2} 毫秒");</p>
登录后复制

基本上就这些。Stopwatch 简单高效,是 C# 中测量执行时间的标准做法。

以上就是C#的Stopwatch类是什么?如何精确地测量代码执行时间?的详细内容,更多请关注php中文网其它相关文章!

相关标签:
最佳 Windows 性能的顶级免费优化软件
最佳 Windows 性能的顶级免费优化软件

每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。

下载
来源:php中文网
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
最新问题
开源免费商场系统广告
热门教程
更多>
最新下载
更多>
网站特效
网站源码
网站素材
前端模板
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号