std::literals::chrono_literals::operator""y

来自cppreference.com
< cpp‎ | chrono
 
 
 
 
在标头 <chrono> 定义
constexpr std::chrono::year operator""y( unsigned long long y ) noexcept;
(C++20 起)

构成表示外推格里高利历中年份的 std::chrono::year 字面量。

参数

y - 年份值

返回值

int(y) 初始化的 std::chrono::year。若转型结果不在 [-3276732767] 中,则存储值未指定。

可能的实现

constexpr std::chrono::year operator""y(unsigned long long y) noexcept
{
    return std::chrono::year(static_cast<int>(y));
}

注解

此运算符在命名空间 std::literals::chrono_literals 声明,其中 literalschrono_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 的公开成员函数)