Namespaces
Variants

std::chrono:: treat_as_floating_point

From cppreference.net
ヘッダーで定義 <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();
    // 浮動小数点数のミリ秒型
    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");
    // 暗黙的な変換はここでは許可されていないことに注意
    auto i_ms = std::chrono::duration_cast<std::chrono::milliseconds>(stop - start);
    // 暗黙的な変換はここで許可されていることに注意
    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

関連項目