std::chrono::year_month_day::operator sys_days, std::chrono::year_month_day::operator local_days

来自cppreference.com
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
 
 
constexpr operator std::chrono::sys_days() const noexcept;
(1) (C++20 起)
constexpr explicit operator std::chrono::local_days() const noexcept;
(2) (C++20 起)

*this 转换成与此 year_month_day 表示同一日期的 std::chrono::time_point

1)ok()true,则返回值保有从 std::chrono::system_clock 纪元 (1970-01-01) 到 *this 的日数总计。若 *this 表示的日期先于纪元,则结果为负。
否则,若存储的 yearmonth 合法(year().ok() && month().ok()true),则返回值为 sys_days(year()/month()/1d) + (day() - 1d)
否则(若 year().ok() && month().ok()false),返回值未指定。
范围 [std::chrono::days{-12687428}, std::chrono::days{11248737}] 中的 std::chrono::sys_days,转换到 year_month_day 再转换回来后,生成相同值。
2)(1),但代之以返回 local_days。等价于 return local_days(sys_days(*this).time_since_epoch());

注解

转换到 std::chrono::sys_days 再转换回来,能用于正规化含有非法 day 但有合法 yearmonthyear_month_day

using namespace std::chrono;
auto ymd = 2017y/January/0;
ymd = sys_days{ymd};
// ymd 现在是 2016y/December/31

能通过加(或减)零个 std::chrono::months 来正规化年和月:

using namespace std::chrono;
constexpr year_month_day normalize(year_month_day ymd)
{
    ymd += months{0}; // 正规化年和月
    return sys_days{ymd}; // 正规化日
}
static_assert(normalize(2017y/33/59) == 2019y/10/29);

示例

#include <chrono>
#include <iostream>
 
int main()
{
    using namespace std::chrono;
    const auto today = sys_days{std::chrono::floor<days>(system_clock::now())};
    for (const year_month_day ymd : {{November/15/2020}, {November/15/2120}, today})
    {
        std::cout << ymd;
        const auto delta = (sys_days{ymd} - today).count();
        (delta < 0) ? std::cout << " 是 " << -delta << " 天前\n" :
        (delta > 0) ? std::cout << " 是现在的 " << delta << " 天后\n"
                    : std::cout << " 是今天!\n";
    }
}

可能的输出:

2020-11-15 是 1014 天前
2120-11-15 是现在的 35510 天后
2023-08-26 是今天!