您的位置:首页 >C++获取当前时间及时间戳转换方法
发布于2026-04-14 阅读(0)
扫一扫,手机访问
现代C++推荐用std::chrono获取Unix时间戳:秒级用duration_cast<seconds>,毫秒级用duration_cast<milliseconds>;格式化需线程安全的localtime_r/gmtime_r及strftime,避免ctime等不安全函数。

std::chrono 获取当前时间戳(秒/毫秒级)现代 C++ 推荐用 std::chrono,它类型安全、无时区歧义,且不依赖 C 风格的全局状态。直接获取 Unix 时间戳(自 1970-01-01 00:00:00 UTC 起的秒数或毫秒数)最稳妥:
std::chrono::system_clock::now().time_since_epoch().count() 返回的是纳秒级计数,需除以对应倍数才能转成秒/毫秒std::chrono::duration_cast 显式转换,避免整数溢出或精度丢失:比如 std::chrono::duration_cast(std::chrono::system_clock::now().time_since_epoch()).count() system_clock 不保证是 UTC(C++20 前),但实践中主流平台(Linux/macOS/MSVC)都按 UTC 实现;若需强保证,应搭配 std::chrono::utc_clock(C++20)std::put_time 格式化为本地时区日期字符串拿到时间戳后想转成 "2024-05-20 14:30:45" 这类可读格式,得先转成 std::tm,再用 std::put_time 输出。关键在「时区」——std::localtime 是线程不安全的,std::localtime_r(POSIX)或 std::localtime_s(Windows)才是安全选择:
std::chrono::system_clock::to_time_t 把时间点转成 time_tstd::localtime_r(&t, &tm_buf),Windows 上用 std::localtime_s(&tm_buf, &t)std::put_time 只接受 const std::tm*,不支持直接传 std::chrono::time_pointstd::localtime 在多线程里导致时间错乱;或忘了初始化 tm_buf 结构体(某些平台会残留脏数据)如果日志、协议或 API 要求严格 UTC 格式(如 ISO 8601),就不能依赖 localtime 系列函数。C++20 引入了 std::format 和 std::chrono::zoned_time,但老标准下只能靠 std::gmtime_r/std::gmtime_s:
std::gmtime_r(&t, &tm_buf)(Linux/macOS)或 std::gmtime_s(&tm_buf, &t)(Windows)获取 UTC 的 tm%Y-%m-%d %H:%M:%S 即可,不用改逻辑std::gmtime 同样线程不安全,必须用带 _r 或 _s 后缀的变体_CRT_SECURE_NO_WARNINGS,std::gmtime_s 可能触发编译警告,需加 #pragma warning(suppress: 4996) 或配置项目属性time() + ctime() 直接拼字符串ctime(&t) 返回的是带换行符的静态字符串(如 "Mon May 20 14:30:45 2024\n"),看似方便,实则暗藏三处硬伤:
ctime 本质调用 localtime,受系统时区环境变量(如 TZ)影响,部署到不同服务器可能结果突变std::strftime 配合线程安全的 localtime_r,哪怕多写两行真正难的不是“怎么转”,而是想清楚你要的是 UTC 还是本地时间、是否并发安全、是否跨平台一致——这些决定一上来就选错函数,后面全得返工。
下一篇:115浏览器官方登录入口官网
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
售后无忧
立即购买>office旗舰店
正版软件
正版软件
正版软件
正版软件
1
2
3
7
9