Namensräume
Varianten
Aktionen

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

Von cppreference.com
 
 
 
 
constexpr std::chrono::year_month_weekday

    operator+( const std::chrono::year_month_weekday& ymwd,

               const std::chrono::months& dm ) noexcept;
(1) (seit C++20)
constexpr std::chrono::year_month_weekday

    operator+( const std::chrono::months& dm,

               const std::chrono::year_month_weekday& ymwd ) noexcept;
(2) (seit C++20)
constexpr std::chrono::year_month_weekday

    operator+( const std::chrono::year_month_weekday& ymwd,

               const std::chrono::years& dy ) noexcept;
(3) (seit C++20)
constexpr std::chrono::year_month_weekday

    operator+( const std::chrono::years& dy,

               const std::chrono::year_month_weekday& ymwd ) noexcept;
(4) (seit C++20)
constexpr std::chrono::year_month_weekday

    operator-( const std::chrono::year_month_weekday& ymwd,

               const std::chrono::months& dm ) noexcept;
(5) (seit C++20)
constexpr std::chrono::year_month_weekday

    operator-( const std::chrono::year_month_weekday& ymwd,

               const std::chrono::years& dy ) noexcept;
(6) (seit C++20)
1,2) Addiert dm.count() Monate zu dem von ymwd dargestellten Datum. Das Ergebnis hat dasselbe year() und month() wie std::chrono::year_month(ymwd.year(), ymwd.month()) + dm und dasselbe weekday() und index() wie ymwd.
3,4) Addiert dy.count() Jahre zu dem von ymwd dargestellten Datum. Das Ergebnis ist äquivalent zu std::chrono::year_month_weekday(ymwd.year() + dy, ymwd.month(), ymwd.weekday_indexed()).
5) Subtrahiert dm.count() Monate von dem von ymwd dargestellten Datum. Äquivalent zu ymwd + -dm.
6) Subtrahiert dy.count() Jahre von dem von ymwd dargestellten Datum. Äquivalent zu ymwd + -dy.

Für Dauern, die sowohl in std::chrono::years als auch in std::chrono::months konvertierbar sind, werden die Überladungen für years (3,4,6) bevorzugt, wenn der Aufruf andernfalls mehrdeutig wäre.

[bearbeiten] Anmerkungen

Auch wenn ymwd.ok() true ist, repräsentiert das resultierende year_month_weekday möglicherweise kein gültiges Datum, wenn ymwd.index() 5 ist.

[bearbeiten] Beispiel

#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);
}

Ausgabe

2021/Jan/Wed[1]
2026/Jan/Wed[1]
2025/Jul/Wed[1]