C++20 时间日期处理完全指南:从基础到高级应用
2025-06-24 08:05:07作者:侯霆垣
引言
C++20 标准库对时间日期处理进行了重大改进,引入了全新的日历和时区支持。本文将深入探讨这些新特性,并通过实际示例展示如何利用它们解决常见的日程安排问题。
基础日历操作
每月固定日期安排
让我们从一个简单的例子开始:安排每月5号的会议。
#include <chrono>
#include <iostream>
int main() {
namespace chr = std::chrono;
using namespace std::literals;
// 初始化2021年1月5日
chr::year_month_day first = 2021y / 1 / 5;
// 遍历全年每月5号
for (auto d = first; d.year() == first.year(); d += chr::months{1}) {
std::cout << d << ":\n";
// 创建18:30的时间点
auto tp{chr::sys_days{d} + 18h + 30min};
std::cout << std::format(" 会议时间: {:%A %D at %R}\n", tp);
}
}
这段代码展示了:
- 使用
year_month_day表示具体日期 - 使用
months持续时间进行月份递增 - 组合日期和时间创建时间点
- 使用格式化输出显示完整信息
日期初始化方式
C++20提供了多种初始化日期的方式:
// 使用字面量
auto d1 = 2021y/1/5; // 2021年1月5日
// 使用标准月份对象
using namespace std::chrono;
auto d2 = January/5/2021;
// 使用不同顺序初始化
auto d3 = 5/1/2021; // 同样表示1月5日
高级日历特性
处理月末日期
安排每月最后一天的会议需要特殊处理:
auto first = 2021y / 1 / chr::last; // 1月最后一天
for (auto d = first; d.year() == first.year(); d += chr::months{1}) {
if (d.ok()) {
std::cout << d << ":\n";
auto tp{chr::sys_days{d} + 18h + 30min};
std::cout << std::format(" 会议时间: {:%A %D at %R}\n", tp);
}
}
关键点:
last表示月份的最后一天ok()方法验证日期有效性- 自动处理不同月份的天数差异
工作日安排
安排每月第一个星期一的会议:
auto first = 2021y / 1 / chr::Monday[1]; // 1月第一个周一
for (auto d = first; d.year() == first.year(); d += chr::months{1}) {
std::cout << d << '\n';
auto tp{chr::sys_days{d} + 18h + 30min};
std::cout << std::format(" 会议时间: {:%A %D at %R}\n", tp);
}
这里使用了weekday_indexed类型表示"第n个星期X"的概念。
时区处理
本地时间与系统时间
// 获取当前本地日期
auto localNow = chr::current_zone()->to_local(chr::system_clock::now());
chr::year_month_day today{chr::floor<chr::days>(localNow)};
// 创建本地时间点
auto tp{chr::local_days{d} + 18h + 30min};
// 应用时区
chr::zoned_time timeLocal{chr::current_zone(), tp};
重要区别:
sys_days:系统时间(UTC)local_days:无时区本地时间zoned_time:特定时区的时间
多时区转换
// 本地时间
chr::zoned_time timeLocal{chr::current_zone(), tp};
// 转换为其他时区
chr::zoned_time timeEurope{"Europe/Berlin", timeLocal};
chr::zoned_time timeUSWest{"America/Los_Angeles", timeLocal};
std::cout << "本地: " << timeLocal << '\n';
std::cout << "欧洲: " << timeEurope << '\n';
std::cout << "太平洋: " << timeUSWest << '\n';
输出示例:
本地: 2021-04-05 18:30:00 CEST
欧洲: 2021-04-05 19:30:00 EEST
太平洋: 2021-04-05 09:30:00 PDT
异常处理与时区数据库
当系统不支持时区数据库时:
try {
auto localNow = chr::current_zone()->to_local(chr::system_clock::now());
// ...其他操作...
} catch (const std::exception& e) {
std::cerr << "错误: " << e.what() << '\n';
}
总结
C++20的时间日期库提供了:
- 类型安全的日历操作
- 灵活的时间点计算
- 强大的时区支持
- 直观的格式化输出
通过这些特性,开发者可以轻松处理复杂的日程安排和跨时区时间转换问题,而无需依赖第三方库。
登录后查看全文
热门项目推荐
atomcodeClaude Code 的开源替代方案。连接任意大模型,编辑代码,运行命令,自动验证 — 全自动执行。用 Rust 构建,极致性能。 | An open-source alternative to Claude Code. Connect any LLM, edit code, run commands, and verify changes — autonomously. Built in Rust for speed. Get StartedRust0214
cann-learning-hubCANN 学习中心仓,支持在线互动运行、边学边练,提供教程、示例与优化方案,一站式助力昇腾开发者快速上手。Jupyter Notebook0138
uni-appA cross-platform framework using Vue.jsJavaScript08
GLM-5.2智谱开源 GLM-5.2,这是针对长文本任务的最新旗舰模型。相较于前代产品 GLM-5.1,它在长文本任务处理能力上实现了显著飞跃,并且首次在稳定的 100 万 token 上下文中提供这一能力。Jinja00
SwanLab⚡️SwanLab - an open-source, modern-design AI training tracking and visualization tool. Supports Cloud / Self-hosted use. Integrated with PyTorch / Transformers / LLaMA Factory / veRL/ Swift / Ultralytics / MMEngine / Keras etc.Python00
tiny-universe《大模型白盒子构建指南》:一个全手搓的Tiny-UniverseJupyter Notebook03
项目优选
收起
deepin linux kernel
C
32
16
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
469
465
暂无描述
Dockerfile
778
5.08 K
本项目是CANN提供的transformer类大模型算子库,实现网络在NPU上加速计算。
C++
877
2.03 K
Ascend Extension for PyTorch
Python
758
968
本项目是CANN提供的神经网络类计算算子库,实现网络在NPU上加速计算。
C++
697
1.4 K
昇腾LLM分布式训练框架
Python
185
231
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
1.1 K
1.14 K
本仓库是 Flutter SDK 与 Flutter Engine 的 OpenHarmony 适配版本,由 CPF-Flutter 团队维护。开发者可使用熟悉的 Flutter 技术栈开发 OpenHarmony 应用,3.35.7 及以后的适配版本可基于本仓库源码构建支持 OpenHarmony 的 Flutter Engine。
Dart
1.04 K
271
JiuwenSwarm 是一款基于openJiuwen开发的智能AI Agent,它能够将大语言模型的强大能力,通过你日常使用的各类通讯应用,直接延伸至你的指尖。
Python
2.25 K
677