0

0

c++中如何计算程序运行时间_c++ clock函数测量耗时方法【实例】

穿越時空

穿越時空

发布时间:2026-01-21 15:55:02

|

484人浏览过

|

来源于php中文网

原创

clock()测量CPU时间而非真实流逝时间,仅统计进程占用CPU的时间,sleep、I/O等待等不计入;需用double转换差值除以CLOCKS_PER_SEC,且存在溢出与跨平台精度问题,推荐用std::chrono替代。

c++中如何计算程序运行时间_c++ clock函数测量耗时方法【实例】

clock() 测量的是 CPU 时间,不是真实流逝时间

clock() 返回自程序启动以来的处理器时钟滴答数(CLOCKS_PER_SEC 滴答为 1 秒),它统计的是当前进程实际占用 CPU 的时间。这意味着:如果程序在 sleep()、等待 I/O 或被系统调度挂起,这部分时间**不会计入** clock() 结果。

常见误用场景:

  • 想测“用户等了多久”,却用了 clock() → 实际得到的是后台计算耗时,远小于感知时长
  • 多线程下只在主线程调用 clock() → 无法反映所有线程总 CPU 消耗
  • 跨平台时假设 CLOCKS_PER_SEC == 1000000 → Windows 下通常是 1000,Linux/macOS 通常是 1000000,不可硬编码

正确用法:用 double 除以 CLOCKS_PER_SEC 得秒数

必须把 clock() 差值转成 double 再除,否则整数除法会截断,尤其在耗时短时结果恒为 0。

include 
#include 

int main() { clock_t start = clock();

// 模拟一段计算
volatile long sum = 0;
for (long i = 0; i zuojiankuohaophpcn 100000000L; ++i) {
    sum += i;
}

clock_t end = clock();
double cpu_time = static_castzuojiankuohaophpcndoubleyoujiankuohaophpcn(end - start) / CLOCKS_PER_SEC;
std::cout zuojiankuohaophpcnzuojiankuohaophpcn "CPU time: " zuojiankuohaophpcnzuojiankuohaophpcn cpu_time zuojiankuohaophpcnzuojiankuohaophpcn " s\n";
return 0;

}

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

关键点:

  • volatile 防止编译器优化掉循环(否则 clock() 可能测到 0)
  • 必须用 static_cast,不能写 (double)(end - start) / CLOCKS_PER_SEC(C 风格转换易出错)
  • CLOCKS_PER_SEC 是宏,不是常量,不能取地址或用于模板非类型参数

更可靠的替代方案:std::chrono::high_resolution_clock

若需测量真实经过时间(wall-clock time),比如接口响应、文件读写、网络请求,应改用 std::chrono

酷兔AI论文
酷兔AI论文

专业原创高质量、低查重,免费论文大纲,在线AI生成原创论文,AI辅助生成论文的神器!

下载
#include 
#include 

int main() { auto start = std::chrono::high_resolution_clock::now();

// 同样模拟计算
volatile long sum = 0;
for (long i = 0; i zuojiankuohaophpcn 100000000L; ++i) {
    sum += i;
}

auto end = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_castzuojiankuohaophpcnstd::chrono::microsecondsyoujiankuohaophpcn(end - start);
std::cout zuojiankuohaophpcnzuojiankuohaophpcn "Wall time: " zuojiankuohaophpcnzuojiankuohaophpcn duration.count() zuojiankuohaophpcnzuojiankuohaophpcn " μs\n";
return 0;

}

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

优势:

  • 返回真实流逝时间,含 sleep、I/O 等全部停顿
  • 精度通常达纳秒级(取决于系统),比 clock() 更稳定
  • 类型安全,支持自动单位转换(millisecondsnanoseconds
  • 无平台差异陷阱,C++11 起标准保证可用

clock() 的最大陷阱:溢出与精度不足

clock_t 通常是 32 位有符号整型。按 CLOCKS_PER_SEC = 1000000 算,约 2147 秒(35 分钟)后就会溢出回负值,导致差值为巨大负数,除出来是负时间。

避免方式:

  • 单次测量不要超过几分钟;长期监控请用 std::chrono::steady_clock
  • 不依赖 clock() 做性能基线对比——不同机器上 CLOCKS_PER_SEC 不同,数值不可比
  • Windows 下 clock() 精度极低(~15ms),短于该值的测量基本无效

真正需要 CPU 时间分析时,优先考虑专用工具(如 perf、Visual Studio Profiler),而不是靠 clock() 手动打点。

相关专题

更多
java基础知识汇总
java基础知识汇总

java基础知识有Java的历史和特点、Java的开发环境、Java的基本数据类型、变量和常量、运算符和表达式、控制语句、数组和字符串等等知识点。想要知道更多关于java基础知识的朋友,请阅读本专题下面的的有关文章,欢迎大家来php中文网学习。

1468

2023.10.24

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

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

53

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

硬盘接口类型介绍
硬盘接口类型介绍

硬盘接口类型有IDE、SATA、SCSI、Fibre Channel、USB、eSATA、mSATA、PCIe等等。详细介绍:1、IDE接口是一种并行接口,主要用于连接硬盘和光驱等设备,它主要有两种类型:ATA和ATAPI,IDE接口已经逐渐被SATA接口;2、SATA接口是一种串行接口,相较于IDE接口,它具有更高的传输速度、更低的功耗和更小的体积;3、SCSI接口等等。

1027

2023.10.19

PHP接口编写教程
PHP接口编写教程

本专题整合了PHP接口编写教程,阅读专题下面的文章了解更多详细内容。

66

2025.10.17

php8.4实现接口限流的教程
php8.4实现接口限流的教程

PHP8.4本身不内置限流功能,需借助Redis(令牌桶)或Swoole(漏桶)实现;文件锁因I/O瓶颈、无跨机共享、秒级精度等缺陷不适用高并发场景。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

455

2025.12.29

java接口相关教程
java接口相关教程

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

11

2026.01.19

Java编译相关教程合集
Java编译相关教程合集

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

5

2026.01.21

热门下载

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

精品课程

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

共48课时 | 7.5万人学习

Git 教程
Git 教程

共21课时 | 2.8万人学习

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

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