std::chrono::operator+,std::chrono::operator-(std::chrono::year_month_weekday)(3) | C++ Standard Libary | std::chrono::operator+,std::chrono::operator-(std::chrono::year_month_weekday)(3) |
NAME¶
std::chrono::operator+,std::chrono::operator-(std::chrono::year_month_weekday) - std::chrono::operator+,std::chrono::operator-(std::chrono::year_month_weekday)
Synopsis¶
constexpr std::chrono::year_month_weekday
operator+( const std::chrono::year_month_weekday& ymwd, (1)
(since C++20)
const std::chrono::months& dm ) noexcept;
constexpr std::chrono::year_month_weekday
operator+( const std::chrono::months& dm, (2) (since
C++20)
const std::chrono::year_month_weekday& ymwd )
noexcept;
constexpr std::chrono::year_month_weekday
operator+( const std::chrono::year_month_weekday& ymwd, (3)
(since C++20)
const std::chrono::years& dy ) noexcept;
constexpr std::chrono::year_month_weekday
operator+( const std::chrono::years& dy, (4) (since
C++20)
const std::chrono::year_month_weekday& ymwd )
noexcept;
constexpr std::chrono::year_month_weekday
operator-( const std::chrono::year_month_weekday& ymwd, (5)
(since C++20)
const std::chrono::months& dm ) noexcept;
constexpr std::chrono::year_month_weekday
operator-( const std::chrono::year_month_weekday& ymwd, (6)
(since C++20)
const std::chrono::years& dy ) noexcept;
1,2) Adds dm.count() months to the date represented by ymwd. The result has
the same
year() and month() as std::chrono::year_month(ymwd.year(), ymwd.month()) + dm
and
the same weekday() and index() as ymwd.
3,4) Adds dy.count() years to the date represented by ymwd. The result is
equivalent
to std::chrono::year_month_weekday(ymwd.year() + dy, ymwd.month(),
ymwd.weekday_indexed()).
5) Subtracts dm.count() months from the date represented by ymwd. Equivalent
to ymwd
+ -dm.
6) Subtracts dy.count() years from the date represented by ymwd. Equivalent
to ymwd
+ -dy.
For durations that are convertible to both std::chrono::years and
std::chrono::months, the years overloads (3,4,6) are preferred if the call
would
otherwise be ambiguous.
Notes¶
Even if ymwd.ok() is true, the resulting year_month_weekday may
not represent a
valid date if ymwd.index() is 5.
Example¶
// Run this code
#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);
}
Output:¶
2021/Jan/Wed[1]
2026/Jan/Wed[1]
2025/Jul/Wed[1]
2024.06.10 | http://cppreference.com |