std::literals::chrono_literals::operator""us

来自cppreference.com
< cpp‎ | chrono
 
 
工具库
语言支持
类型支持(基本类型、RTTI)
库功能特性测试宏 (C++20)
动态内存管理
程序工具
协程支持 (C++20)
变参数函数
调试支持
(C++26)
三路比较
(C++20)
(C++20)(C++20)(C++20)
(C++20)(C++20)(C++20)
通用工具
日期和时间
函数对象
格式化库 (C++20)
(C++11)
关系运算符 (C++20 中弃用)
整数比较函数
(C++20)(C++20)(C++20)   
(C++20)
交换类型运算
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
常用词汇类型
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
初等字符串转换
(C++17)
(C++17)

 
 
 
在标头 <chrono> 定义
constexpr std::chrono::microseconds
    operator""us( unsigned long long us );
(1) (C++14 起)
constexpr std::chrono::duration</* 未指明 */, std::micro>
    operator""us( long double us );
(2) (C++14 起)

组成表示微秒的 std::chrono::duration 字面量。

1) 整数字面量,准确返回 std::chrono::microseconds(us)
2) 浮点字面量,返回等价于 std::chrono::microseconds 的浮点时长。

参数

us - 微秒数

返回值

std::chrono::duration 字面量。

可能的实现

constexpr std::chrono::microseconds operator""us(unsigned long long us)
{
    return std::chrono::microseconds(us);
}
constexpr std::chrono::duration<long double, std::micro> operator""us(long double us)
{
    return std::chrono::duration<long double, std::micro>(us);
}

注解

此运算符在命名空间 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::chrono_literals;
    auto d1 = 250us;
    std::chrono::microseconds d2 = 1ms;
    std::cout << d1 << " = " << d1.count() << " 微秒\n"
              << 1ms << " = " << d2.count() << " 微秒\n";
}

输出:

250us = 250 微秒
1ms = 1000 微秒

参阅

构造新 duration
(std::chrono::duration<Rep,Period> 的公开成员函数)