std::chrono::weekday:: weekday
From cppreference.net
|
weekday
(
)
=
default
;
|
(1) | (начиная с C++20) |
|
constexpr
explicit
weekday
(
unsigned
wd
)
noexcept
;
|
(2) | (начиная с C++20) |
|
constexpr
weekday
(
const
std::
chrono
::
sys_days
&
sd
)
noexcept
;
|
(3) | (начиная с C++20) |
|
constexpr
explicit
weekday
(
const
std::
chrono
::
local_days
&
ld
)
noexcept
;
|
(4) | (начиная с C++20) |
Создает объект
weekday
.
1)
Конструктор по умолчанию оставляет значение дня недели неинициализированным.
2)
Создает объект
weekday
, содержащий значение дня недели
wd
. Если
wd
==
7
, хранимое значение равно
0
. Если
wd
>
255
, хранимое значение не определено.
3)
Создает объект
weekday
, представляющий день недели, которому соответствует
sd
. Этот конструктор определяет неявное преобразование из
std::chrono::sys_days
в
weekday
.
4)
Создает объект
weekday
, представляющий день недели, которому соответствует
ld
, как если бы с помощью
weekday
(
std::
chrono
::
sys_days
(
ld.
time_since_epoch
(
)
)
)
.
Параметры
| wd | - | значение дня недели |
| sd | - | объект системных дней |
| ld | - | объект локальных дней |
Пример
Запустить этот код
#include <chrono> #include <iomanip> #include <iostream> int main() { constexpr std::chrono::weekday friday{5}; // использует перегрузку (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 << " is " << friday << '\n'; } } }
Вывод:
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