std::chrono是C++11引入的类型安全时间库,核心组件包括time_point、duration和clock,可用于精确计时、线程延迟和时间格式化;通过high_resolution_clock测量代码耗时,结合sleep_for或sleep_until实现精准休眠,利用system_clock与ctime配合输出可读时间字符串,并支持毫秒等高精度处理,适用于性能分析与定时任务。

在C++中,std::chrono 是一个功能强大且类型安全的时间处理库,自 C++11 起引入,广泛用于计时、延迟控制和时间点管理。它提供了高精度的时间测量能力,适用于性能分析、定时任务、休眠控制等场景。下面介绍其核心组件及常见应用方式。
计时:测量代码执行时间
使用 std::chrono::high_resolution_clock 可以精确测量一段代码的运行时间。常用做法是记录起始和结束时间点,然后计算差值。
示例:测量函数执行耗时
#include <chrono>
#include <iostream>
#include <thread>
<p>int main() {
auto start = std::chrono::high_resolution_clock::now();</p><pre class='brush:php;toolbar:false;'>// 模拟工作
std::this_thread::sleep_for(std::chrono::milliseconds(500));
auto end = std::chrono::high_resolution_clock::now();
auto duration = std::chrono::duration_cast<std::chrono::microseconds>(end - start);
std::cout << "耗时: " << duration.count() << " 微秒\n";
return 0;}
立即学习“C++免费学习笔记(深入)”;
关键类型说明:
-
time_point:表示某一时刻,如
high_resolution_clock::now() - duration:表示时间段,如毫秒、微秒等
- duration_cast:用于在不同精度的 duration 之间转换
延迟:让程序暂停指定时间
结合 std::this_thread::sleep_for 和 std::this_thread::sleep_until,可以实现精确的线程休眠。
示例:使用 sleep_for 延迟 1.5 秒
#include <chrono>
#include <thread>
#include <iostream>
<p>int main() {
std::cout << "开始...\n";</p><pre class='brush:php;toolbar:false;'>std::this_thread::sleep_for(std::chrono::seconds(1) +
std::chrono::milliseconds(500));
std::cout << "1.5秒后继续\n";
return 0;}
立即学习“C++免费学习笔记(深入)”;
也可以使用 sleep_until 指定一个具体时间点唤醒:
auto target = std::chrono::high_resolution_clock::now() +
std::chrono::seconds(2);
std::this_thread::sleep_until(target);
时间格式化:将时间点转为可读字符串
std::chrono 本身不直接支持格式化输出(如 YYYY-MM-DD HH:MM:SS),但可以与 C 风格的 <ctime> 结合使用。
示例:将当前系统时间格式化输出
#include <chrono>
#include <iostream>
#include <ctime>
<p>int main() {
auto now = std::chrono::system_clock::now();
std::time_t time_t = std::chrono::system_clock::to_time_t(now);
std::tm* tm = std::localtime(&time_t);</p><pre class='brush:php;toolbar:false;'>char buffer[64];
std::strftime(buffer, sizeof(buffer), "%Y-%m-%d %H:%M:%S", tm);
std::cout << "当前时间: " << buffer << "\n";
return 0;}
立即学习“C++免费学习笔记(深入)”;
注意:
- 使用 system_clock 获取日历时间(Unix 时间戳)
-
to_time_t将 time_point 转为 time_t 类型 -
localtime转换为本地时间结构 -
strftime按格式写入字符串
如果需要更高精度(如包含毫秒),可手动提取:
auto now = std::chrono::system_clock::now(); auto duration = now.time_since_epoch(); auto seconds = std::chrono::duration_cast<std::chrono::seconds>(duration); auto millis = std::chrono::duration_cast<std::chrono::milliseconds>(duration) % 1000; <p>std::time_t time_t = seconds.count(); // ... 格式化秒部分,再拼接毫秒</p>
基本上就这些。std::chrono 提供了现代 C++ 中处理时间的标准方式,避免了传统 time.h 的不安全性,同时支持高精度操作。掌握 time_point、duration 和 clock 的配合使用,能有效应对大多数时间相关需求。不复杂但容易忽略的是单位转换和时区处理——建议始终明确使用 system_clock 或 steady_clock,根据用途选择。对于更复杂的格式化或时区支持,可考虑第三方库如 Howard Hinnant's date 库或 C++20 的 chrono 扩展。











