0

0

C#怎么使用Stopwatch精确计时_C#如何测量算法执行时间【示例】

尼克

尼克

发布时间:2026-03-18 10:47:29

|

440人浏览过

|

来源于php中文网

原创

Stopwatch.StartNew() 是最安全的初始化方式,它自动完成实例化和启动,避免因遗漏 Start() 导致 Elapsed 为 0;应复用实例并用 Restart() 分段计时,慎用 ElapsedMilliseconds 防精度丢失。

c#怎么使用stopwatch精确计时_c#如何测量算法执行时间【示例】

Stopwatch.StartNew() 是最安全的初始化方式

直接调用 Stopwatch.StartNew(),别先 new 再 Start —— 后者多一步就可能漏掉 Start(),导致 Elapsed 始终为 0。这个静态方法内部自动完成实例化和启动,语义清晰、不易出错。

常见错误现象:stopwatch.Elapsed.TotalMilliseconds 总是返回 0,检查发现忘了调用 Start() 或误调了 Restart()(它只重置不启动)。

  • Stopwatch.StartNew() 返回已启动的实例,开箱即用
  • 手动 new:var sw = new Stopwatch(); sw.Start(); 多一环节,协作时容易被删掉 Start()
  • 不要用 Stopwatch.IsHighResolution 判断能否用——它只是说明底层是否支持高精度,不影响 StartNew() 行为

计时区间必须严格配对 Stop() 和 Restart()

Stopwatch 不是“自动暂停”的秒表;Stop() 后再 Elapsed 就冻结了,想继续测下一段,得用 Restart()(等价于 Stop() + Start()),而不是再次 Start()(重复 Start 会报 InvalidOperationException)。

典型场景:循环中逐次测量每次迭代耗时,或分阶段测「预处理→主计算→后处理」。

  • 错误写法:sw.Start(); DoWork(); sw.Stop(); sw.Start(); DoMore(); → 第二次 Start() 抛异常
  • 正确写法:sw.Restart(); DoWork(); sw.Stop();sw.Stop(); ... sw.Start();(中间确保没重复 Start)
  • 如果只关心总耗时,全程不用 Stop(),最后直接读 Elapsed 即可

避免在 Stopwatch 运行时读取 ElapsedMilliseconds 等整型属性

ElapsedMillisecondslong 类型的只读属性,但它会截断毫秒后的小数部分。实际底层计时器精度常达微秒级(尤其 IsHighResolution == true 时),直接用它会丢精度,且在极短时间(

使用场景:算法执行时间通常很短,靠 ElapsedMilliseconds 很难区分 0.2ms 和 0.8ms 的差异。

AIPURE
AIPURE

AIPURE帮您轻松找到2024年最佳AI工具

下载
  • 优先用 Elapsed.TotalMillisecondsdouble,含小数)或 ElapsedTicks(原始计数,无舍入)
  • 注意 TotalMilliseconds 是 double,做相等判断要小心浮点误差;比大小可用 > 0.01 这类阈值
  • 跨平台时,.NET 5+ 在 Windows/Linux/macOS 上都默认启用高精度计时器,无需额外配置

Stopwatch 本身不引发 GC,但别把它塞进热循环里反复 new

Stopwatch 是 struct,栈上分配,没 GC 压力。但频繁调用 Stopwatch.StartNew() 仍会带来微小构造开销,尤其在每毫秒执行多次的热点路径中。

容易被忽略的地方:有人为“线程安全”每个线程都 new 一个,结果对象创建频次远超必要——Stopwatch 实例本就是线程私有的,复用完全没问题。

  • 单次测量:用 Stopwatch.StartNew() 最省心
  • 高频重复测量(如性能压测循环):复用同一个实例,Restart() 比 new 更轻量
  • 别为了“避免共享”把 Stopwatch 放进 static 字段——它不是线程安全的共享资源,每个线程该有自己的实例

Stopwatch 的精度取决于系统计时器,Windows 上通常是 10–15ms 的默认分辨率,但 .NET 会自动尝试启用高精度模式(QueryPerformanceCounter)。真正影响结果的,往往不是 Stopwatch 本身,而是你测的那段代码有没有被 JIT 预热、有没有被内联、GC 是否恰好在中间发生——这些比选哪个属性读数更值得盯住。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

WorkBuddy
WorkBuddy

腾讯云推出的AI原生桌面智能体工作台

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
堆和栈的区别
堆和栈的区别

堆和栈的区别:1、内存分配方式不同;2、大小不同;3、数据访问方式不同;4、数据的生命周期。本专题为大家提供堆和栈的区别的相关的文章、下载、课程内容,供大家免费下载体验。

448

2023.07.18

堆和栈区别
堆和栈区别

堆(Heap)和栈(Stack)是计算机中两种常见的内存分配机制。它们在内存管理的方式、分配方式以及使用场景上有很大的区别。本文将详细介绍堆和栈的特点、区别以及各自的使用场景。php中文网给大家带来了相关的教程以及文章欢迎大家前来学习阅读。

606

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

806

2023.08.10

windows查看端口占用情况
windows查看端口占用情况

Windows端口可以认为是计算机与外界通讯交流的出入口。逻辑意义上的端口一般是指TCP/IP协议中的端口,端口号的范围从0到65535,比如用于浏览网页服务的80端口,用于FTP服务的21端口等等。怎么查看windows端口占用情况呢?php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

1562

2023.07.26

查看端口占用情况windows
查看端口占用情况windows

端口占用是指与端口关联的软件占用端口而使得其他应用程序无法使用这些端口,端口占用问题是计算机系统编程领域的一个常见问题,端口占用的根本原因可能是操作系统的一些错误,服务器也可能会出现端口占用问题。php中文网给大家带来了相关的教程以及文章,欢迎大家前来学习阅读。

1172

2023.07.27

windows照片无法显示
windows照片无法显示

当我们尝试打开一张图片时,可能会出现一个错误提示,提示说"Windows照片查看器无法显示此图片,因为计算机上的可用内存不足",本专题为大家提供windows照片无法显示相关的文章,帮助大家解决该问题。

838

2023.08.01

windows查看端口被占用的情况
windows查看端口被占用的情况

windows查看端口被占用的情况的方法:1、使用Windows自带的资源监视器;2、使用命令提示符查看端口信息;3、使用任务管理器查看占用端口的进程。本专题为大家提供windows查看端口被占用的情况的相关的文章、下载、课程内容,供大家免费下载体验。

463

2023.08.02

windows无法访问共享电脑
windows无法访问共享电脑

在现代社会中,共享电脑是办公室和家庭的重要组成部分。然而,有时我们可能会遇到Windows无法访问共享电脑的问题。这个问题可能会导致数据无法共享,影响工作和生活的正常进行。php中文网给大家带来了相关的教程以及文章,欢迎大家前来阅读学习。

2363

2023.08.08

Python WebSocket实时通信与异步服务开发实践
Python WebSocket实时通信与异步服务开发实践

本专题聚焦 Python 在实时通信场景中的开发实践,系统讲解 WebSocket 协议原理、长连接管理、消息推送机制以及异步服务架构设计。内容包括客户端与服务端通信实现、连接稳定性优化、消息队列集成及高并发处理策略。通过完整案例,帮助开发者构建高效稳定的实时通信系统,适用于聊天应用、实时数据推送等场景。

3

2026.03.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
C# 教程
C# 教程

共94课时 | 11.6万人学习

C 教程
C 教程

共75课时 | 5.6万人学习

C++教程
C++教程

共115课时 | 22.4万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

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