Namespaces
Variants

std::chrono:: time_point_cast

From cppreference.net
ヘッダーで定義 <chrono>
template < class ToDuration, class Clock, class Duration >

std:: chrono :: time_point < Clock, ToDuration >

time_point_cast ( const std:: chrono :: time_point < Clock, Duration > & t ) ;
(C++11以降)
(C++14以前)
template < class ToDuration, class Clock, class Duration >

constexpr std:: chrono :: time_point < Clock, ToDuration >

time_point_cast ( const std:: chrono :: time_point < Clock, Duration > & t ) ;
(C++14以降)

std::chrono::time_point をある期間から別の期間に変換します。

time_point_cast は、 ToDuration std::chrono::duration の特殊化である場合にのみ、オーバーロード解決に参加します。

目次

パラメータ

t - time_point 変換元の時間点

戻り値

std:: chrono :: time_point < Clock, ToDuration > (
std:: chrono :: duration_cast < ToDuration > ( t. time_since_epoch ( ) ) )
.

#include <chrono>
#include <iostream>
using namespace std::chrono_literals;
using Clock = std::chrono::high_resolution_clock;
using Ms = std::chrono::milliseconds;
using Sec = std::chrono::seconds;
template<class Duration>
using TimePoint = std::chrono::time_point<Clock, Duration>;
inline void print_ms(const TimePoint<Ms>& time_point)
{
    std::cout << time_point.time_since_epoch().count() << " ms\n";
}
int main()
{
    TimePoint<Sec> time_point_sec{4s};
    // 暗黙的変換、精度損失なし
    TimePoint<Ms> time_point_ms = time_point_sec;
    print_ms(time_point_ms); // 4000 ms
    time_point_ms = TimePoint<Ms>{5756ms};
    print_ms(time_point_ms); // 5756 ms
    // 明示的キャスト、精度損失が発生する可能性がある場合に必要
    // 5756 が 5000 に切り捨てられる
    time_point_sec = std::chrono::time_point_cast<Sec>(time_point_ms);
    print_ms(time_point_sec); // 5000 ms
}

出力:

4000 ms
5756 ms
5000 ms

関連項目

time_pointを別のtime_pointに変換し、切り捨てを行う
(関数テンプレート)
time_pointを別のtime_pointに変換し、切り上げを行う
(関数テンプレート)
time_pointを別のtime_pointに変換し、最近接偶数への丸めを行う
(関数テンプレート)
durationを別のdurationに変換し、異なる刻み間隔で表現する
(関数テンプレート)