std::chrono::system_clock::now() 获取自1970-01-01 UTC起的纳秒级时间点,需用 to_time_t() 转为 time_t 后才能通过 ctime 等函数输出可读时间。

C++中如何获取系统当前时间?(使用chrono库实现)

std::chrono::system_clock 获取当前时间点

std::chrono::system_clock 是 C++11 起标准库中表示系统实时时钟的类型,它返回的是自纪元(通常是 1970-01-01 00:00:00 UTC)以来的纳秒级时间点。直接调用 now() 即可拿到当前时间点:

auto now = std::chrono::system_clock::now();

注意:返回值是 std::chrono::time_point<system_clock, duration> 类型,不能直接打印或比较,需转为 time_t 或字符串才能使用。

转成 time_t 再用 std::ctime 输出可读时间

大多数传统时间函数(如 std::localtimestd::gmtime)只接受 time_t,所以得先用 to_time_t() 转换:

auto now = std::chrono::system_clock::now();
std::time_t t = std::chrono::system_clock::to_time_t(now);
std::cout << std::ctime(&t); // 输出类似 "Wed Jun 12 15:23:45 2024\n"

常见错误:直接对 now 调用 std::ctime 会编译失败,因为参数类型不匹配。

std::put_time 格式化输出(推荐)

比起 std::ctime 的固定格式,std::put_time 支持自定义格式,且能保留 system_clock::to_time_t 转换后的秒级时间(再配合 duration_cast 补毫秒):

auto now = std::chrono::system_clock::now();
auto time_t = std::chrono::system_clock::to_time_t(now);
auto ms = std::chrono::duration_cast(now.time_since_epoch()) % 1000;

std::cout << std::put_time(std::localtime(&time_t), "%Y-%m-%d %H:%M:%S");
std::cout << '.' << std::setfill('0') << std::setw(3) << ms.count() << '\n';

关键点:

跨平台注意事项和精度陷阱

system_clock 在不同平台实现不同:Linux/macOS 通常基于 clock_gettime(CLOCK_REALTIME),Windows 上早期 MSVC 实现精度只有 15ms 左右(VS2015 后已改善)。不要假设它一定能返回毫秒或微秒级稳定精度。

真正需要精确到毫秒的日志时间戳,建议统一用 system_clock::now() 存储原始 time_point,只在最终展示时格式化——避免反复转换引入误差。

本文转载于:互联网 如有侵犯,请联系zhengruancom@outlook.com删除。
免责声明:正软商城发布此文仅为传递信息,不代表正软商城认同其观点或证实其描述。