名前空間
変種
操作

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

From cppreference.com
< cpp‎ | chrono
 
 
 
 
ヘッダー <chrono> で定義
constexpr std::chrono::microseconds
    operator""us( unsigned long long us );
(1) (C++14以降)
constexpr std::chrono::duration</*unspecified*/, 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」名前空間に宣言されています。ここで「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;」を使用して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() << " microseconds\n"
              << 1ms << " = " << d2.count() << " microseconds\n";
}

出力

250us = 250 microseconds
1ms = 1000 microseconds

[編集] 関連項目

新しいdurationを構築する
(std::chrono::duration<Rep,Period> の public member function) [編集]
English 日本語 中文(简体) 中文(繁體)