std::chrono::year_month_day:: year_month_day
|
year_month_day
(
)
=
default
;
|
(1) | (начиная с C++20) |
|
constexpr
year_month_day
(
const
std::
chrono
::
year
&
y,
const
std::
chrono
::
month
&
m,
|
(2) | (начиная с C++20) |
|
constexpr
year_month_day
(
const
std::
chrono
::
year_month_day_last
&
ymdl
)
noexcept
;
|
(3) | (начиная с C++20) |
|
constexpr
year_month_day
(
const
std::
chrono
::
sys_days
&
dp
)
noexcept
;
|
(4) | (начиная с C++20) |
|
constexpr
explicit
year_month_day
(
const
std::
chrono
::
local_days
&
dp
)
noexcept
;
|
(5) | (начиная с C++20) |
Создает объект
year_month_day
.
year_month_day
, который хранит год
y
, месяц
m
и день
d
.
year_month_day
, который хранит год
ymdl.
year
(
)
, месяц
ymdl.
month
(
)
и день
ymdl.
day
(
)
.
year_month_day
, который представляет ту же дату, что и дата, представленная
dp
.
year_month_day
, который представляет ту же дату, что и дата, представленная
dp
, как если бы это было сделано с помощью
year_month_day
(
sys_days
(
dp.
time_since_epoch
(
)
)
)
.
Конструкторы (3,4) определяют неявные преобразования из std::chrono::year_month_day_last и std::chrono::sys_days соответственно.
Для любого объекта
year_month_day
ymd
представляющего корректную дату (
ymd.
ok
(
)
==
true
), преобразование
ymd
в
sys_days
и обратно дает то же самое значение.
Примечания
Объект
year_month_day
также может быть создан путём комбинирования одного из типов частичной даты
std::chrono::year_month
и
std::chrono::month_day
с отсутствующим компонентом (днём и годом соответственно) с использованием
operator
/
.
Пример
#include <chrono> #include <iostream> int main() { using namespace std::chrono; constexpr auto ymd2 = std::chrono::year_month_day( 2020y, std::chrono::January, 31d // перегрузка (2) ); std::cout << "ymd2: " << ymd2 << '\n'; constexpr auto ymd3 = std::chrono::year_month_day( std::chrono::April / std::chrono::Monday[last] / 2023y // перегрузка (3) ); std::cout << "ymd3: " << ymd3 << '\n'; const auto now = std::chrono::system_clock::now(); const auto ymd4 = std::chrono::year_month_day( std::chrono::floor<std::chrono::days>(now) // перегрузка (4) ); std::cout << "ymd4: " << ymd4 << '\n'; }
Возможный вывод:
ymd2: 2020-01-31 ymd3: 2023-04-24 ymd4: 2023-08-30
Смотрите также
|
(C++20)
|
традиционный синтаксис для создания дат григорианского календаря
(функция) |