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 в другой, округляя до ближайшего, при равенстве к чётному
(шаблон функции)
преобразует duration в другой с другим интервалом тиков
(шаблон функции)