C++如何获取当前时间_C++ chrono库高精度计时与时间戳转换

使用std::chrono::system_clock获取当前时间戳(秒或毫秒),2. 用std::chrono::steady_clock测量代码执行时间,确保高精度与稳定性。

c++如何获取当前时间_c++ chrono库高精度计时与时间戳转换

在C++中获取当前时间并进行高精度计时,chrono 库是首选工具。它从 C++11 开始引入,提供了纳秒级的时间精度和类型安全的时间操作方式,适用于性能分析、日志记录、超时控制等场景。

获取当前时间与系统时间点

std::chrono::system_clock 是最常用的时钟,用于获取自 Unix 纪元(1970年1月1日 00:00:00 UTC)以来的时间点。

示例:获取当前时间戳(秒)

auto now = std::chrono::system_clock::now();
auto timestamp = std::chrono::duration_cast(now.time_since_epoch()).count();
// 输出类似:1712345678

获取毫秒级时间戳

auto ms_timestamp = std::chrono::duration_cast(now.time_since_epoch()).count();
// 更精确,常用于日志或网络协议

高精度计时:测量代码执行时间

使用 steady_clock 可避免系统时间调整带来的影响,适合测量时间间隔。

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

示例:测量函数耗时

auto start = std::chrono::steady_clock::now();

// 模拟耗时操作
for (int i = 0; i   volatile int x = i * i;
}

auto end = std::chrono::steady_clock::now();
auto duration = std::chrono::duration_cast(end – start);
std::cout

支持的精度单位包括:
– nanoseconds(纳秒)
– microseconds(微秒)
– milliseconds(毫秒)
– seconds(秒)
可根据需要自由转换。

时间戳转日期字符串

将时间点转换为可读格式,需结合 ctimestrftime 使用。

示例:时间戳转 YYYY-MM-DD HH:MM:SS

auto now = std::chrono::system_clock::now();
auto time_t_now = std::chrono::system_clock::to_time_t(now);
char buf[100];
std::strftime(buf, sizeof(buf), “%Y-%m-%d %H:%M:%S”, std::localtime(&time_t_now));
std::cout

若需更高精度,可在格式化后附加毫秒部分:

auto ms = std::chrono::duration_cast(now.time_since_epoch()) % 1000;
std::cout // 输出如:2024-04-05 10:23:45.123

基本上就这些。chrono 库简洁高效,掌握 system_clock 获取时间戳、steady_clock 做性能计时、配合 duration_cast 转换单位,就能应对大多数时间处理需求。不复杂但容易忽略的是选择合适的时钟类型——测时间用 steady_clock,要日期用 system_clock。

以上就是C++如何获取当前时间_C++ chrono库高精度计时与时间戳转换的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1487751.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月19日 10:58:04
下一篇 2025年12月19日 10:58:22

相关推荐

发表回复

登录后才能评论
关注微信