std::chrono::operator+, std::chrono::operator- (std::chrono::year_month_weekday)
From cppreference.com
< cpp | chrono | year month weekday
| constexpr std::chrono::year_month_weekday operator+( const std::chrono::year_month_weekday& ymwd, |
(1) | (C++20以降) |
| constexpr std::chrono::year_month_weekday operator+( const std::chrono::months& dm, |
(2) | (C++20以降) |
| constexpr std::chrono::year_month_weekday operator+( const std::chrono::year_month_weekday& ymwd, |
(3) | (C++20以降) |
| constexpr std::chrono::year_month_weekday operator+( const std::chrono::years& dy, |
(4) | (C++20以降) |
| constexpr std::chrono::year_month_weekday operator-( const std::chrono::year_month_weekday& ymwd, |
(5) | (C++20以降) |
| constexpr std::chrono::year_month_weekday operator-( const std::chrono::year_month_weekday& ymwd, |
(6) | (C++20以降) |
1,2) dm.count()ヶ月を、ymwdが表す日付に加算します。結果は、std::chrono::year_month(ymwd.year(), ymwd.month()) + dmと同じ
year()とmonth()を持ち、ymwdと同じweekday()とindex()を持ちます。3,4) dy.count()年を、ymwdが表す日付に加算します。結果は、std::chrono::year_month_weekday(ymwd.year() + dy, ymwd.month(), ymwd.weekday_indexed())と等価です。
5) dm.count()ヶ月を、ymwdが表す日付から減算します。ymwd + -dmと等価です。
6) dy.count()年を、ymwdが表す日付から減算します。ymwd + -dyと等価です。
std::chrono::yearsとstd::chrono::monthsの両方に変換可能な期間の場合、呼び出しが曖昧になる可能性があるときは、yearsのオーバーロード (3,4,6) が優先されます。
[編集] 注釈
ymwd.ok()がtrueであっても、ymwd.index()が5である場合、結果のyear_month_weekdayは有効な日付を表さない場合があります。
[編集] 例
このコードを実行
#include <cassert> #include <chrono> #include <iostream> int main() { auto ymwdi{1/std::chrono::Wednesday[1]/2021}; std::cout << ymwdi << '\n'; ymwdi = std::chrono::years(5) + ymwdi; // First Wednesday in January, 2026 std::cout << ymwdi << '\n'; assert(static_cast<std::chrono::year_month_day>(ymwdi) == std::chrono::January/7/2026); ymwdi = ymwdi - std::chrono::months(6); // First Wednesday in July, 2025 std::cout << ymwdi << '\n'; assert(static_cast<std::chrono::year_month_day>(ymwdi) == std::chrono::July/2/2025); }
出力
2021/Jan/Wed[1] 2026/Jan/Wed[1] 2025/Jul/Wed[1]