std::chrono::year_month_day:: operator+=, std::chrono::year_month_day:: operator-=
From cppreference.net
<
cpp
|
chrono
|
year month day
|
constexpr
std::
chrono
::
year_month_day
&
operator + = ( const std:: chrono :: years & dy ) const noexcept ; |
(1) | (depuis C++20) |
|
constexpr
std::
chrono
::
year_month_day
&
operator + = ( const std:: chrono :: months & dm ) const noexcept ; |
(2) | (depuis C++20) |
|
constexpr
std::
chrono
::
year_month_day
&
operator - = ( const std:: chrono :: years & dy ) const noexcept ; |
(3) | (depuis C++20) |
|
constexpr
std::
chrono
::
year_month_day
&
operator - = ( const std:: chrono :: months & dm ) const noexcept ; |
(4) | (depuis C++20) |
Modifie le point temporel représenté par * this par la durée dy ou dm .
1)
Équivalent à
*
this
=
*
this
+
dy
;
.
2)
Équivalent à
*
this
=
*
this
+
dm
;
.
3)
Équivalent à
*
this
=
*
this
-
dy
;
.
4)
Équivalent à
*
this
=
*
this
-
dm
;
.
Pour les durées qui sont convertibles à la fois en
std::chrono::years
et en
std::chrono::months
, les surcharges de
years
(1,3)
sont préférées si l'appel serait autrement ambigu.
Exemple
Exécuter ce code
#include <cassert> #include <chrono> #include <iostream> int main() { constexpr auto monthsInYear{12}; auto ymd{std::chrono::day(1)/std::chrono::July/2020}; std::cout << "#1 " << ymd << '\n'; ymd -= std::chrono::years(10); std::cout << "#2 " << ymd << '\n'; assert(ymd.month() == std::chrono::July); assert(ymd.year() == std::chrono::year(2010)); ymd += std::chrono::months(10 * monthsInYear + 11); std::cout << "#3 " << ymd << '\n'; assert(ymd.month() == std::chrono::month(6)); assert(ymd.year() == std::chrono::year(2021)); // Gestion du cas de "débordement" avec ymd += months. ymd = std::chrono::May/31/2021; // ok std::cout << "#4 " << ymd << '\n'; assert(ymd.ok()); ymd += std::chrono::months{1}; // date invalide : juin n'a que 30 jours std::cout << "#5 " << ymd << '\n'; assert(not ymd.ok()); assert(ymd == std::chrono::June/31/2021); // Ajustement au dernier jour du mois, 30 juin : const auto ymd1 = ymd.year()/ymd.month()/std::chrono::last; std::cout << "#6 " << ymd1 << '\n'; assert(ymd1.ok()); assert(ymd1 == std::chrono::June/30/2021); // Débordement dans le mois suivant, 1er juillet (via conversion vers/depuis sys_days) : const std::chrono::year_month_day ymd2 = std::chrono::sys_days{ymd}; std::cout << "#7 " << ymd2 << '\n'; assert(ymd2.ok()); assert(ymd2 == std::chrono::July/1/2021); }
Sortie :
#1 2020-07-01 #2 2010-07-01 #3 2021-06-01 #4 2021-05-31 #5 2021-06-31 is not a valid date #6 2021/Jun/last #7 2021-07-01
Voir aussi
|
(C++20)
|
ajoute ou soustrait un
year_month_day
et un certain nombre d'années ou de mois
(fonction) |