std::chrono:: operator+, std::chrono:: operator- (std::chrono::year_month_day)
|
Défini dans l'en-tête
<chrono>
|
||
|
constexpr
std::
chrono
::
year_month_day
operator
+
(
const
std::
chrono
::
year_month_day
&
ymd,
const
std::
chrono
::
months
&
dm
|
(depuis C++20) | |
|
constexpr
std::
chrono
::
year_month_day
operator
+
(
const
std::
chrono
::
months
&
dm,
const
std::
chrono
::
year_month_day
&
ymd
|
(depuis C++20) | |
|
constexpr
std::
chrono
::
year_month_day
operator
+
(
const
std::
chrono
::
year_month_day
&
ymd,
const
std::
chrono
::
years
&
dy
|
(depuis C++20) | |
|
constexpr
std::
chrono
::
year_month_day
operator
+
(
const
std::
chrono
::
years
&
dy,
const
std::
chrono
::
year_month_day
&
ymd
|
(depuis C++20) | |
|
constexpr
std::
chrono
::
year_month_day
operator
-
(
const
std::
chrono
::
year_month_day
&
ymd,
const
std::
chrono
::
months
&
dm
|
(depuis C++20) | |
|
constexpr
std::
chrono
::
year_month_day
operator
-
(
const
std::
chrono
::
year_month_day
&
ymd,
const
std::
chrono
::
years
&
dy
|
(depuis C++20) | |
Pour les durées qui sont convertibles à la fois en
std::chrono::years
et en
std::chrono::months
, les surcharges
years
(3,4,6)
sont préférées si l'appel serait autrement ambigu.
Notes
Même si
ymd.
ok
(
)
est
true
, le
year_month_day
résultant peut ne pas représenter une date valide si
ymd.
day
(
)
vaut 29, 30 ou 31.
Exemple
#include <chrono> #include <iostream> int main() { std::cout << std::boolalpha; auto ymd{std::chrono::day(1)/std::chrono::July/2021}; ymd = ymd + std::chrono::months(4); std::cout << (ymd.month() == std::chrono::November) << ' ' << (ymd.year() == std::chrono::year(2021)) << ' '; ymd = ymd - std::chrono::years(10); std::cout << (ymd.month() == std::chrono::month(11)) << ' ' << (ymd.year() == std::chrono::year(2011)) << '\n'; }
Sortie :
true true true true