std::chrono::treat_as_floating_point
From cppreference.com
| ヘッダー <chrono> で定義 |
||
| template< class Rep > struct treat_as_floating_point : std::is_floating_point<Rep> {}; |
(C++11以降) | |
std::chrono::treat_as_floating_point トレイトは、ある期間が異なるティック周期を持つ別の期間に変換できるかどうかを判断するのに役立ちます。
通常、2つの期間間の暗黙的な変換は、期間のティック周期に依存します。しかし、std::chrono::treat_as_floating_point<Rep>::value が true の場合、ティック周期に関係なく暗黙的な変換が発生する可能性があります。
目次 |
[編集] ヘルパー変数テンプレート
| template< class Rep > constexpr bool treat_as_floating_point_v = treat_as_floating_point<Rep>::value; |
(C++17以降) | |
[編集] 特殊化
std::chrono::treat_as_floating_point は、プログラム定義型に対して特殊化される場合があります。
[編集] 例
このコードを実行
#include <chrono> #include <iostream> #include <thread> void timed_piece_of_code() { std::chrono::milliseconds simulated_work(2); std::this_thread::sleep_for(simulated_work); } int main() { auto start = std::chrono::high_resolution_clock::now(); std::cout << "Running some timed piece of code...\n"; timed_piece_of_code(); auto stop = std::chrono::high_resolution_clock::now(); // A floating point milliseconds type using FpMilliseconds = std::chrono::duration<float, std::chrono::milliseconds::period>; static_assert(std::chrono::treat_as_floating_point<FpMilliseconds::rep>::value, "Rep required to be floating point"); // Note that implicit conversion is not allowed here auto i_ms = std::chrono::duration_cast<std::chrono::milliseconds>(stop - start); // Note that implicit conversion is allowed here auto f_ms = FpMilliseconds(stop - start); std::cout << "Timing stats:\n"; std::cout << " Time in milliseconds, using default rep: " << i_ms.count() << '\n'; std::cout << " Time in milliseconds, using floating point rep: " << f_ms.count() << '\n'; }
実行結果の例
Running some timed piece of code... Timing stats: Time in milliseconds, using default rep: 2 Time in milliseconds, using floating point rep: 2.57307