close
Пространства имён
Варианты
Действия

std::chrono::month_day::ok

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
 
std::chrono::month_day
Функции-элементы
Функции, не являющиеся элементами
Вспомогательные классы
 
<tbody> </tbody>
constexpr bool ok() const noexcept;
(начиная с C++20)

Определяет, хранит ли этот month_day действительную комбинацию месяца и дня.

Комбинация действительна, если month() представляет действительный месяц (month().ok() == true), unsigned{day()} >= 1 и unsigned{day()} <= D, где D это количество дней в месяце, представленном month(). Количество дней в феврале считается равным 29.

Возвращаемое значение

true, если комбинация месяца и дня действительна, иначе false.

Пример

#include <iostream>
#include <chrono>

int main()
{
    std::cout << std::boolalpha;

    constexpr auto md1 {std::chrono::July/15};
    std::cout << (md1.ok()) << ' ';
    constexpr std::chrono::month_day md2 {std::chrono::month(14), std::chrono::day(42)};
    std::cout << (md2.ok()) << ' ';
    constexpr auto md3 {std::chrono::February/29};
    std::cout << (md3.ok()) << '\n';
}

Вывод:

true false true