std::chrono::year_month_day:: ok
From cppreference.net
<
cpp
|
chrono
|
year month day
C++
Date and time library
|
|
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
std::chrono::year_month_day
| Member functions | ||||
|
year_month_day::ok
|
||||
| Nonmember functions | ||||
| Helper classes | ||||
|
constexpr
bool
ok
(
)
const
noexcept
;
|
(C++20以降) | |
この
year_month_day
オブジェクトが有効な暦日を表しているかどうかをチェックします。
戻り値
true
この
year_month_day
オブジェクトが有効な暦日を表す場合、つまり格納されている年、月、日の値がすべて有効であり、格納されている日値が指定された年と月の日数内にある場合。それ以外の場合は
false
。
実装例
constexpr bool std::chrono::year_month_day::ok() const noexcept { return year().ok() && month().ok() && day().ok() && day() <= (year()/month()/std::chrono::last).day(); } |
例
このコードを実行
#include <chrono> int main() { constexpr auto ymd1 {std::chrono::day(1)/std::chrono::July/2020}; static_assert(ymd1.ok()); constexpr auto ymd2 {std::chrono::year(2020)/7/42}; static_assert(not ymd2.ok()); constexpr auto ymd3 {std::chrono::February/29/2020}; // OK、閏年 static_assert(ymd3.ok()); constexpr auto ymd4 = ymd3 + std::chrono::years{1}; // 不正、閏年ではない static_assert(ymd4 == std::chrono::February/29/2021 and not ymd4.ok()); // 不正な日付を修正するには、月の最終日にスナップする方法があります: if constexpr (!ymd4.ok()) { constexpr auto ymd = ymd4.year()/ymd4.month()/std::chrono::last; static_assert(ymd == std::chrono::February/28/2021 and ymd.ok()); } // または、翌月にオーバーフローさせる方法もあります: if constexpr (!ymd4.ok()) { constexpr auto st = std::chrono::sys_time<std::chrono::days>{ymd4}; constexpr auto ymd = std::chrono::year_month_day{st}; static_assert(ymd == std::chrono::March/1/2021 and ymd.ok()); } }