std::chrono::year_month_day:: year_month_day
|
year_month_day
(
)
=
default
;
|
(1) | (desde C++20) |
|
constexpr
year_month_day
(
const
std::
chrono
::
year
&
y,
const
std::
chrono
::
month
&
m,
|
(2) | (desde C++20) |
|
constexpr
year_month_day
(
const
std::
chrono
::
year_month_day_last
&
ymdl
)
noexcept
;
|
(3) | (desde C++20) |
|
constexpr
year_month_day
(
const
std::
chrono
::
sys_days
&
dp
)
noexcept
;
|
(4) | (desde C++20) |
|
constexpr
explicit
year_month_day
(
const
std::
chrono
::
local_days
&
dp
)
noexcept
;
|
(5) | (desde C++20) |
Construye un objeto
year_month_day
.
year_month_day
que almacena el año
y
, mes
m
y día
d
.
year_month_day
que almacena el año
ymdl.
year
(
)
, el mes
ymdl.
month
(
)
y el día
ymdl.
day
(
)
.
year_month_day
que representa la misma fecha que la representada por
dp
.
year_month_day
que representa la misma fecha que la representada por
dp
, como si fuera mediante
year_month_day
(
sys_days
(
dp.
time_since_epoch
(
)
)
)
.
Constructores (3,4) definen conversiones implícitas desde std::chrono::year_month_day_last y std::chrono::sys_days , respectivamente.
Para cualquier objeto
year_month_day
ymd
que represente una fecha válida (
ymd.
ok
(
)
==
true
), convertir
ymd
a
sys_days
y volver produce el mismo valor.
Notas
Un
year_month_day
también puede crearse combinando uno de los tipos de fecha parcial
std::chrono::year_month
y
std::chrono::month_day
con el componente faltante (día y año, respectivamente) usando
operator
/
.
Ejemplo
#include <chrono> #include <iostream> int main() { using namespace std::chrono; constexpr auto ymd2 = std::chrono::year_month_day( 2020y, std::chrono::January, 31d // sobrecarga (2) ); std::cout << "ymd2: " << ymd2 << '\n'; constexpr auto ymd3 = std::chrono::year_month_day( std::chrono::April / std::chrono::Monday[last] / 2023y // sobrecarga (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) // sobrecarga (4) ); std::cout << "ymd4: " << ymd4 << '\n'; }
Salida posible:
ymd2: 2020-01-31 ymd3: 2023-04-24 ymd4: 2023-08-30
Véase también
|
(C++20)
|
sintaxis convencional para la creación de fechas del calendario gregoriano
(función) |