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; 取得对日期时间库中的类的访问时,对应的字面量运算符也会变为可见。
示例
运行此代码
#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' // 未指明 << static_cast<unsigned>(298d) << '\t' << 298d << '\n'; // 未指明 }
可能的输出:
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 的公开成员函数) |