Namespaces
Variants

std::chrono::weekday:: weekday

From cppreference.net
weekday ( ) = default ;
(1) (depuis C++20)
constexpr explicit weekday ( unsigned wd ) noexcept ;
(2) (depuis C++20)
constexpr weekday ( const std:: chrono :: sys_days & sd ) noexcept ;
(3) (depuis C++20)
constexpr explicit weekday ( const std:: chrono :: local_days & ld ) noexcept ;
(4) (depuis C++20)

Construit un objet weekday .

1) Le constructeur par défaut laisse la valeur du jour de la semaine non initialisée.
2) Construit un objet weekday contenant la valeur de jour de la semaine wd . Si wd == 7 , la valeur contenue est 0 . Si wd > 255 , la valeur contenue est non spécifiée.
3) Construit un objet weekday représentant le jour de la semaine auquel sd correspond. Ce constructeur définit une conversion implicite de std::chrono::sys_days vers weekday .
4) Construit un objet weekday représentant le jour de la semaine auquel ld correspond, comme par weekday ( std:: chrono :: sys_days ( ld. time_since_epoch ( ) ) ) .

Paramètres

wd - une valeur de jour de semaine
sd - un objet system days
ld - un objet local days

Exemple

#include <chrono>
#include <iomanip>
#include <iostream>
int main()
{
    constexpr std::chrono::weekday friday{5}; // utilise la surcharge (2)
    static_assert(friday == std::chrono::Friday);
    for (int y{2020}; y <= 2024; ++y)
    {
        const std::chrono::year cur_year{y};
        for (int cur_month{1}; cur_month != 13; ++cur_month)
        {
            const std::chrono::year_month_day ymd{cur_year/cur_month/13};
            const std::chrono::weekday cur_weekday{std::chrono::sys_days(ymd)}; // (3)
            if (cur_weekday == friday)
                std::cout << ymd << " est " << friday << '\n';
        }
    }
}

Sortie :

2020-03-13 is Fri
2020-11-13 is Fri
2021-08-13 is Fri
2022-05-13 is Fri
2023-01-13 is Fri
2023-10-13 is Fri
2024-09-13 is Fri
2024-12-13 is Fri