C++20新增chrono日历与时区支持,提供year、month、day等类型及year_month_day组合,实现类型安全的日期操作,无需第三方库即可处理复杂时间计算。

C++20 引入了对 chrono 库的重大扩展,新增了日历(Calendar)和时区(time zone)支持,让处理日期、星期、年月日以及时区转换变得直观且类型安全。这些功能定义在 <chrono> 头文件中,无需第三方库即可完成复杂的日期时间操作。
1. 基本日历类型:年、月、日、星期
C++20 提供了表示日历组件的类型,如 year、month、day、weekday,以及组合类型 year_month_day。
// 构造一个具体的日期
std::chrono::year y{2025};
立即学习“C++免费学习笔记(深入)”;
std::chrono::month m{3};
std::chrono::day d{28};
std::chrono::year_month_day date{y, m, d};
if (date.ok()) {
std::cout (y) (m)
(d)
}
你也可以从 sys_days(自1970-01-01起的天数)反向构造:
auto today = std::chrono::floor<:chrono::days>(
std::chrono::system_clock::now());
std::chrono::year_month_day ymd{today};
std::cout
2. 获取星期几和月份名称
使用 weekday 可获取某天是星期几。
std::chrono::weekday wd = std::chrono::weekday{ymd.day()};
std::cout
// 或者获取数字(0=Sun, 1=Mon, …)
std::cout
也可判断是否为有效日期:
std::chrono::year_month_day bad_date{2025y/13/40};
if (!bad_date.ok()) {
std::cout
}
3. 时区操作:带时区的时间处理
C++20 支持通过 zoned_time 和 current_zone() 等处理本地与不同时区的时间。
// 获取当前系统时间
auto now = std::chrono::system_clock::now();
// 获取本地时区
const std::chrono::time_zone* tz =
std::chrono::current_zone();
// 绑定时间和时区
std::chrono::zoned_time local_time{tz, now};
std::cout
转换到其他时区也很简单:
// 转换为东京时间
auto tokyo = std::chrono::locate_zone(“Asia/Tokyo”);
std::chrono::zoned_time tz_time{“Asia/Tokyo”, now};
std::cout
注意:时区数据库需要运行环境支持(如 Linux 下通常自带,Windows 需额外配置或使用兼容层)。
4. 格式化输出日期时间
C++20 支持使用 std::format 或流输出格式化时间。
#include <format>
auto now = std::chrono::system_clock::now();
std::cout
// 输出如:2025-03-28 14:30:22
也可以格式化带时区的时间:
std::chrono::zoned_time zt{“America/New_York”, now};
std::cout
// 输出如:2025-03-28 03:30:22 EST
常见格式符:
-
%Y:四位年份 -
%m:月份(01-12) -
%d:日期(01-31) -
%H:小时(00-23) -
%M:分钟(00-59) -
%S:秒 -
%Z:时区缩写 -
%F:等价于 %Y-%m-%d -
%T:等价于 %H:%M:%S
基本上就这些。C++20 的 chrono 扩展让日期和时区操作变得清晰、安全且可读性强,避免了传统 time_t 和 struct tm 的繁琐与易错。


