std::literals::chrono_literals::operator""y
来自cppreference.com
在标头 <chrono> 定义
|
||
constexpr std::chrono::year operator""y( unsigned long long y ) noexcept; |
(C++20 起) | |
构成表示外推格里高利历中年份的 std::chrono::year 字面量。
参数
y | - | 年份值 |
返回值
从 int(y) 初始化的 std::chrono::year。若转型结果不在 [
-32767,
32767]
中,则存储值未指定。
可能的实现
constexpr std::chrono::year operator""y(unsigned long long y) noexcept { return std::chrono::year(static_cast<int>(y)); } |
注解
此运算符在命名空间 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; std::cout << int(2020y) << '\t' << 2020y << '\n' << int(-220y) << '\t' << -220y << '\n' << int(3000y) << '\t' << 3000y << '\n' << int(32768y) << '\t' << 32768y << '\n' // 未指明 << int(65578y) << '\t' << 65578y << '\n'; // 未指明 }
可能的输出:
2020 2020 -220 -0220 3000 3000 -32768 -32768 is not a valid year 42 0042
参阅
构造 year ( std::chrono::year 的公开成员函数) |