std::literals::chrono_literals::operator""s
提供: cppreference.com
ヘッダ <chrono> で定義
|
||
constexpr chrono::seconds operator "" s(unsigned long long secs); |
(1) | (C++14以上) |
constexpr chrono::duration</*unspecified*/> operator "" s(long double secs); |
(2) | (C++14以上) |
秒を表す std::chrono::duration のリテラルを形成します。
1) 整数リテラル。 正確に std::chrono::seconds(secs) を返します。
2) 浮動小数点リテラル。 std::chrono::seconds と同等な浮動小数点の duration を返します。
目次 |
[編集] 引数
secs | - | 秒数 |
[編集] 戻り値
std::chrono::duration のリテラル。
[編集] 実装例
constexpr std::chrono::seconds operator ""s(unsigned long long s) { return std::chrono::seconds(s); } constexpr std::chrono::duration<long double> operator ""s(long double s) { return std::chrono::duration<long double>(s); } |
[編集] ノート
これらの演算子は名前空間 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 ライブラリのクラスへのアクセスを得ると、対応するリテラル演算子も同様に可視になります。
std::string
型のリテラルオブジェクトを表すために std::string も operator""s
を定義していますが、そちらは文字列リテラルです。 10s は10秒ですが、 "10"s は2文字の文字列です。
[編集] 例
Run this code
#include <iostream> #include <chrono> int main() { using namespace std::chrono_literals; auto halfmin = 30s; std::cout << "half a minute is " << halfmin.count() << " seconds\n" << "a minute and a second is " << (1min + 1s).count() << " seconds\n"; }
出力:
half a minute is 30 seconds a minute and a second is 61 seconds
[編集] 関連項目
新しい時間を構築します ( std::chrono::duration<Rep,Period> のパブリックメンバ関数)
|