std::literals::chrono_literals::operator""y
来自cppreference.com
| 在标头 <chrono> 定义
|
||
| |
(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::literalsusing namespace std::chrono_literalsusing 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 的公开成员函数)
|