0

0

C++怎么计算程序运行时间_C++高精度计时器方法【技巧】

冰火之心

冰火之心

发布时间:2026-03-16 14:08:31

|

774人浏览过

|

来源于php中文网

原创

最可靠方式是用 std::chrono::high_resolution_clock 配合 duration_cast;它底层调用系统高精度计时器,精度远超 GetTickCount64() 和 clock(),且跨平台、防优化、可测真实耗时。

c++怎么计算程序运行时间_c++高精度计时器方法【技巧】

std::chrono 测单次执行耗时最可靠

Windows 上用 GetTickCount64() 或旧式 clock() 容易翻车,前者精度只有 10–16ms,后者还受 CLOCKS_PER_SEC 限制(Linux 常为 100 万,但 Windows 是 1000),测短任务基本不准。C++11 起 std::chrono 是唯一推荐路径,底层对接系统高精度计时器(如 Windows 的 QueryPerformanceCounter,Linux 的 clock_gettime(CLOCK_MONOTONIC))。

实操建议:

  • 固定用 std::chrono::high_resolution_clock —— 不要写成 steady_clocksystem_clock,前者是标准里“最高可用精度”的保证,后两者不承诺精度
  • 时间差必须用 duration_cast 显式转,比如 std::chrono::nanoseconds,直接 .count() 会返回未指定单位的整数,容易误读
  • 别在循环里反复调用 now() 测函数内联开销——现代编译器可能优化掉,真要压测得关优化(-O0)或加 volatile 防止误判
auto start = std::chrono::high_resolution_clock::now();
do_work();
auto end = std::chrono::high_resolution_clock::now();
auto ns = std::chrono::duration_cast<std::chrono::nanoseconds>(end - start).count();

测多轮平均耗时要防编译器优化和缓存干扰

单纯跑一次 now() 差值,对微秒级函数意义不大;真实场景需要多次运行取平均,但这时编译器可能把循环整个优化掉,或者 CPU 缓存让后续迭代快得离谱,数据失真。

常见错误现象:

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

  • 开启 -O2 后,空循环测出来是 0ns —— 因为编译器发现没副作用,直接删了
  • 连续跑 1000 次 sqrt(42.0),第一次 50ns,后面全 1ns —— L1 缓存+分支预测全就位,不代表真实负载

实操建议:

  • volatile 强制读写内存(比如把结果存到 volatile double result),阻止编译器削除计算
  • 每次迭代前加 std::atomic_thread_fence(std::memory_order_seq_cst),防止指令重排干扰起点
  • 真正压测时,先热身 10–20 次再计时,跳过冷启动抖动

跨平台精度差异:Windows 和 Linux 的 high_resolution_clock 实际表现不同

标准只说它是“最高可用精度”,没规定具体值。Windows 下 high_resolution_clock::period::den 通常是 10⁷(即 100ns 级),Linux 下常为 10⁹(1ns 级),但实际分辨率还取决于硬件和内核配置。别硬编码假设 1ns 精度。

OpenJobs AI
OpenJobs AI

AI驱动的职位搜索推荐平台

下载

使用场景:

  • 做性能对比(A 函数比 B 快多少)—— 只要同平台、同编译器,相对值可信
  • 写 benchmark 库或 CI 耗时断言 —— 必须运行时查 high_resolution_clock::period::num / period::den,按实际精度设容差(比如误差 > 3 倍最小刻度就报警)
  • 日志打点记耗时 —— 直接用 microseconds 就够,人眼根本看不出 100ns 和 200ns 区别

别用 std::clock() 测 wall-clock 时间

std::clock() 返回的是进程**CPU 时间**,不是真实流逝时间。多线程下它只累加当前线程占用的 CPU 片段,sleep、IO 等待、其他线程干活都不算进去。测网络请求或磁盘读写,它可能报 0ms,纯误导。

典型错误:

  • auto t0 = clock(); sleep(1000); auto t1 = clock();,结果 t1-t0 接近 0 —— 因为 sleep 不消耗 CPU
  • 用它判断算法“快慢”,但实际程序卡在锁或系统调用上,clock() 完全不反映

替代方案就一个:std::chrono::high_resolution_clock。哪怕只是想粗略看秒级耗时,也用 std::chrono::steady_clock::now(),它至少保证单调递增且测的是真实时间。

真正难的不是选哪个 API,而是理解你到底想测什么:是 CPU 算力瓶颈?还是端到端延迟?或是某段代码在特定负载下的稳定性?选错目标,再准的计时器也白搭。

热门AI工具

更多
DeepSeek
DeepSeek

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

豆包大模型
豆包大模型

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

WorkBuddy
WorkBuddy

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

腾讯元宝
腾讯元宝

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

文心一言
文心一言

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

讯飞写作
讯飞写作

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

即梦AI
即梦AI

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

ChatGPT
ChatGPT

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

相关专题

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

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

203

2023.11.20

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

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

335

2025.08.29

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

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

108

2025.10.23

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

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

77

2025.10.23

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

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

786

2023.08.10

Python 多线程与异步编程实战
Python 多线程与异步编程实战

本专题系统讲解 Python 多线程与异步编程的核心概念与实战技巧,包括 threading 模块基础、线程同步机制、GIL 原理、asyncio 异步任务管理、协程与事件循环、任务调度与异常处理。通过实战示例,帮助学习者掌握 如何构建高性能、多任务并发的 Python 应用。

379

2025.12.24

java多线程相关教程合集
java多线程相关教程合集

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

33

2026.01.21

C++多线程相关合集
C++多线程相关合集

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

31

2026.01.21

C++多线程并发控制与线程安全设计实践
C++多线程并发控制与线程安全设计实践

本专题围绕 C++ 在高性能系统开发中的并发控制技术展开,系统讲解多线程编程模型与线程安全设计方法。内容包括互斥锁、读写锁、条件变量、原子操作以及线程池实现机制,同时结合实际案例分析并发竞争、死锁避免与性能优化策略。通过实践讲解,帮助开发者掌握构建稳定高效并发系统的关键技术。

2

2026.03.16

热门下载

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

精品课程

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

共94课时 | 11.4万人学习

C 教程
C 教程

共75课时 | 5.5万人学习

C++教程
C++教程

共115课时 | 22.1万人学习

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

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