std::chrono::year_month_day::operator sys_days, std::chrono::year_month_day::operator local_days
來自 cppreference.com
< cpp | chrono | year month day
constexpr operator std::chrono::sys_days() const noexcept; |
(1) | (C++20 起) |
constexpr explicit operator std::chrono::local_days() const noexcept; |
(2) | (C++20 起) |
將 *this 轉換成 std::chrono::time_point,表示與此 year_month_day
相同的日期。
1) 若 ok() 為 true,則返回值持有從 std::chrono::system_clock 紀元 (1970-01-01) 到 *this 的天數。若 *this 表示之前的日期,則結果為負。
否則,若所儲存的年和月合法(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 再轉換回來可用於規範化包含非法日但合法年月日的 year_month_day
using namespace std::chrono; auto ymd = 2017y/January/0; ymd = sys_days{ymd}; // ymd is now 2016y/December/31
年和月的規範化可以透過新增(或減去)零 std::chrono::months 來完成
using namespace std::chrono; constexpr year_month_day normalize(year_month_day ymd) { ymd += months{0}; // normalizes year and month return sys_days{ymd}; // normalizes day } 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 << " was " << -delta << " day(s) ago\n" : (delta > 0) ? std::cout << " is " << delta << " day(s) from now\n" : std::cout << " is today!\n"; } }
可能的輸出
2020-11-15 was 1014 day(s) ago 2120-11-15 is 35510 day(s) from now 2023-08-26 is today!