0

0

c++如何使用std::chrono进行程序计时_c++ 代码段执行时间高精度测量【技巧】

裘德小鎮的故事

裘德小鎮的故事

发布时间:2026-01-04 17:19:04

|

1004人浏览过

|

来源于php中文网

原创

c++kquote>应优先使用 std::chrono::steady_clock 测量执行时间,因其严格单调且不受系统时间调整影响;high_resolution_clock 虽常用但跨平台行为不一致,system_clock 则可能被 NTP 等干扰。

c++如何使用std::chrono进行程序计时_c++ 代码段执行时间高精度测量【技巧】

std::chrono::high_resolution_clock 是最常用但不总是最准的选择

多数场景下用 std::chrono::high_resolution_clock 没问题,但它在不同平台行为不一致:Windows 上通常映射到 QueryPerformanceCounter,Linux 上可能是 clock_gettime(CLOCK_MONOTONIC),但 C++ 标准只要求它“尽可能高精度”,不保证单调性或跨平台一致性。若需严格单调、抗系统时间调整,应改用 std::chrono::steady_clock

  • 测量代码段执行时间,优先选 std::chrono::steady_clock —— 它不随系统时间跳变而偏移
  • high_resolution_clock 在某些旧编译器(如 GCC 4.8)可能退化为 system_clock,导致毫秒级误差
  • 不要用 system_clock 测执行时间——它反映挂钟时间,可能被 NTP 调整、夏令时等干扰

正确获取两次时间点并计算差值的写法

核心是避免隐式类型转换丢失精度,且必须用 duration_cast 显式转换单位。直接对 time_point 做减法得到的是 duration,但它的底层计数器单位因实现而异(纳秒/微秒/拍秒),不能直接当浮点数用。

auto start = std::chrono::steady_clock::now();
// ... your code ...
auto end = std::chrono::steady_clock::now();
auto elapsed = std::chrono::duration_cast(end - start);
std::cout << "Time: " << elapsed.count() << " ns\n";
  • duration_cast 而非 C 风格强转:(double)(end - start).count() 会截断,且单位不明
  • 若要毫秒浮点值,写成 std::chrono::duration(end - start).count()
  • 避免把 now() 结果存成 auto 后跨作用域使用——某些 libstdc++ 实现中,time_point 的模板参数过深可能导致 ODR 违规

重复测量时要注意 warmup 和编译器优化干扰

单次测量容易受 CPU 频率突变、缓存未命中、指令重排影响。实际性能分析必须做多次采样,并剔除异常值。同时,编译器可能把“无副作用”的待测代码整个优化掉。

  • volatileasm volatile("" ::: "memory") 防止关键计算被优化(尤其纯计算型代码段)
  • 首次运行前加一次 warmup:调用待测函数一次,让指令/数据进入 L1 缓存和分支预测器
  • 至少测 5–10 次,取中位数而非平均值——避免被某次缺页或中断拉高耗时
  • std::chrono::nanoseconds::min() 判断是否真有耗时(某些极快操作可能返回 0)

Windows 下 QueryPerformanceCounter 的替代方案更可控

如果你在 Windows 上需要确定性最高的结果,且已知目标环境支持,可绕过 std::chrono 直接调用 WinAPI:QueryPerformanceFrequency + QueryPerformanceCounter。它比标准库封装少一层抽象,也规避了某些 MSVC 版本中 steady_clock::now() 的锁竞争开销。

剪映专业版
剪映专业版

一款全能易用的桌面端剪辑软件

下载

立即学习C++免费学习笔记(深入)”;

  • 仅限 Windows;Linux 应用请坚持用 steady_clock + clock_gettime(CLOCK_MONOTONIC)
  • 注意 QueryPerformanceCounter 在某些虚拟机或老 CPU 上可能不准(TSC 不稳定),需检查 QueryPerformanceFrequency 返回值是否 > 0
  • 标准库的 steady_clock 在现代 MSVC(19.20+)和 Clang/LLVM 中已基本等价于该 API,除非你正在调试 nanosecond 级别抖动,否则不必手动替换

精度不是靠选对时钟就万事大吉的——CPU 频率缩放、上下文切换、TLB miss、甚至 std::chrono::now() 自身调用开销(通常几十纳秒)都会混入测量结果。真正可靠的性能对比,永远依赖统计方法和可控环境。

相关专题

更多
counta和count的区别
counta和count的区别

Count函数用于计算指定范围内数字的个数,而CountA函数用于计算指定范围内非空单元格的个数。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

197

2023.11.20

c++怎么把double转成int
c++怎么把double转成int

本专题整合了 c++ double相关教程,阅读专题下面的文章了解更多详细内容。

52

2025.08.29

C++中int、float和double的区别
C++中int、float和double的区别

本专题整合了c++中int和double的区别,阅读专题下面的文章了解更多详细内容。

99

2025.10.23

c++中volatile关键字的作用
c++中volatile关键字的作用

本专题整合了c++中volatile关键字的相关内容,阅读专题下面的文章了解更多详细内容。

69

2025.10.23

C++类型转换方式
C++类型转换方式

本专题整合了C++类型转换相关内容,想了解更多相关内容,请阅读专题下面的文章。

299

2025.07.15

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

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

578

2023.07.26

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

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

1104

2023.07.27

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

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

792

2023.08.01

高德地图升级方法汇总
高德地图升级方法汇总

本专题整合了高德地图升级相关教程,阅读专题下面的文章了解更多详细内容。

72

2026.01.16

热门下载

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

精品课程

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

共48课时 | 7.4万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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