命名空间
变体
操作

std::chrono::month_day::ok

来自 cppreference.com
< cpp‎ | chrono‎ | month day
 
 
实用程序库
语言支持
类型支持 (基本类型,RTTI)
库功能测试宏 (C++20)
动态内存管理
程序实用程序
协程支持 (C++20)
可变参数函数
调试支持
(C++26)
三向比较
(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)

 
 
 
constexpr bool ok() const noexcept;
(自 C++20 起)

确定此 month_day 是否存储有效的月-日组合。

如果 month() 表示一个有效的月份 (month().ok() == true),unsigned{day()} >= 1,并且 unsigned{day()} <= D, 其中 D 是由 month() 表示的月份中的天数,则该组合有效。2 月份的天数被认为是 29 天。

[编辑] 返回值

如果月-日组合有效,则为 true,否则为 false。

[编辑] 示例

#include <chrono>
#include <iostream>
 
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