Namespaces
Variants

std::chrono:: operator+, std::chrono:: operator- (std::chrono::year_month_day)

From cppreference.net
Défini dans l'en-tête <chrono>
(depuis C++20)
(depuis C++20)
constexpr std:: chrono :: year_month_day operator + ( const std:: chrono :: year_month_day & ymd,

const std:: chrono :: years & dy

) noexcept ;
(depuis C++20)
constexpr std:: chrono :: year_month_day operator + ( const std:: chrono :: years & dy,

const std:: chrono :: year_month_day & ymd

) noexcept ;
(depuis C++20)
(depuis C++20)
constexpr std:: chrono :: year_month_day operator - ( const std:: chrono :: year_month_day & ymd,

const std:: chrono :: years & dy

) noexcept ;
(depuis C++20)
1,2) Ajoute dm. count ( ) mois à la date représentée par ymd . Le résultat a le même day ( ) que ymd et la même year ( ) et month ( ) que std:: chrono :: year_month ( ymd. year ( ) , ymd. month ( ) ) + dm .
3,4) Ajoute dy. count ( ) années à la date représentée par ymd . Le résultat est équivalent à std:: chrono :: year_month_day ( ymd. year ( ) + dy, ymd. month ( ) , ymd. day ( ) .
5) Soustrait dm. count ( ) mois de la date représentée par ymd . Équivalent à ymd + - dm .
6) Soustrait dy. count ( ) années de la date représentée par ymd . Équivalent à ymd + - dy .

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