std::chrono::year_month_weekday::operator sys_days, std::chrono::year_month_weekday::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_weekday 表示同一日期的 std::chrono::time_point

1)year().ok() && month().ok() && weekday().ok()
  • index() == 0,则返回表示该年月的首个 weekday() 的 7 日前的日期的 sys_days
  • 其他情况下,返回表示该年月的首个 weekday()(index() - 1) * 7 日后的日期的 sys_days
否则,返回值未指定。
2)(1),但返回 local_days 而非 sys_days。等价于 local_days(sys_days(*this).time_since_epoch())

示例

#include <chrono>
#include <iostream>
using namespace std::chrono;
 
int main()
{
    constexpr auto ymwd{Tuesday[2]/11/2021};
    std::cout << ymwd << '\n';
    // 从基于字段转换为基于序数,以便添加小时
    constexpr auto sd = sys_days{ymwd} + 24h;
    std::cout << sd << '\n';
    constexpr auto ymd = floor<days>(sd);
    static_assert(ymd == November/10/2021);
}

输出:

2021/Nov/Tue[2]
2021-11-10 00:00:00