std::literals::chrono_literals::operator""d
来自 cppreference.com
定义在头文件 <chrono> 中 |
||
constexpr std::chrono::day operator ""d( unsigned long long d ) noexcept; |
(自 C++20) | |
形成一个表示日历中某个月份的某一天的 std::chrono::day 字面量。
内容 |
[编辑] 参数
d | - | 日期值 |
[编辑] 返回值
一个存储 d 的 std::chrono::day。如果 d > 255,则存储的值未定义。
[编辑] 可能的实现
constexpr std::chrono::day operator ""d(unsigned long long d) noexcept { return std::chrono::day(d); } |
[编辑] 注意
此运算符在命名空间 std::literals::chrono_literals 中声明,其中 literals 和 chrono_literals 都是 内联命名空间。可以使用以下方法访问此运算符:
- using namespace std::literals,
- using namespace std::chrono_literals,或
- using namespace std::literals::chrono_literals.
此外,在命名空间 std::chrono 中,指令 using namespace literals::chrono_literals; 由 标准库 提供,因此,如果程序员使用 using namespace std::chrono; 来访问 chrono 库 中的类,相应的字面量运算符也会变得可见。
[编辑] 示例
运行此代码
#include <chrono> #include <iostream> int main() { using namespace std::literals::chrono_literals; std::cout << static_cast<unsigned>(42d) << '\t' << 42d << '\n' << static_cast<unsigned>(256d) << '\t' << 256d << '\n' // unspecified << static_cast<unsigned>(298d) << '\t' << 298d << '\n'; // unspecified }
可能的输出
42 42 is not a valid day 0 00 is not a valid day 42 42 is not a valid day
[编辑] 参见
构造一个 day ( std::chrono::day 的公共成员函数) | |
检索存储的日期值 ( std::chrono::day 的公共成员函数) |