std::chrono::floor(std::chrono::duration)
Материал из cppreference.com
Определено в заголовочном файле <chrono>
|
||
template <class ToDuration, class Rep, class Period> constexpr ToDuration floor(const std::chrono::duration<Rep, Period>& d); |
(начиная с C++17) | |
Возвращает наибольшую длительность t
, представленную в ToDuration
, которая меньше или равна d.
Функция не участвует в разрешении перегрузки, если только ToDuration
не является специализацией std::chrono::duration.
Содержание |
[править] Параметры
d | — | длительность для преобразования |
[править] Возвращаемое значение
d округляется до длительности типа ToDuration
.
[править] Возможная реализация
namespace detail { template<class> inline constexpr bool is_duration_v = false; template<class Rep, class Period> inline constexpr bool is_duration_v< std::chrono::duration<Rep, Period>> = true; } template <class To, class Rep, class Period, class = std::enable_if_t<detail::is_duration_v<To>>> constexpr To floor(const duration<Rep, Period>& d) { To t = std::chrono::duration_cast<To>(d); if (t > d) return t - To{1}; return t; } |
[править] Пример
Запустить этот код
#include <iostream> #include <iomanip> #include <chrono> int main() { using namespace std::chrono_literals; std::cout << "Длительность\tПол\tОкругление\tПотолок\n"; for (using Sec = std::chrono::seconds; auto const d : {+4999ms, +5000ms, +5001ms, +5499ms, +5500ms, +5999ms, -4999ms, -5000ms, -5001ms, -5499ms, -5500ms, -5999ms}) std::cout << std::showpos << d << "\t\t" << std::chrono::floor<Sec>(d) << '\t' << std::chrono::round<Sec>(d) << "\t\t" << std::chrono::ceil <Sec>(d) << '\n'; }
Вывод:
Длительность Пол Округление Потолок +4999ms +4s +5s +5s +5000ms +5s +5s +5s +5001ms +5s +5s +6s +5499ms +5s +5s +6s +5500ms +5s +6s +6s +5999ms +5s +6s +6s -4999ms -5s -5s -4s -5000ms -5s -5s -5s -5001ms -6s -5s -5s -5499ms -6s -5s -5s -5500ms -6s -6s -5s -5999ms -6s -6s -5s
[править] Смотрите также
(C++11) |
преобразует duration в другой duration с другим интервалом тиков (шаблон функции) |
(C++17) |
преобразует duration в другой, округляя в большую сторону (шаблон функции) |
(C++17) |
преобразует duration в другой, округляя до ближайшего, или до чётного в промежуточных случаях (шаблон функции) |
преобразует time_point в другой, округляя в меньшую сторону (шаблон функции) | |
(C++11)(C++11) |
ближайшее целое число не больше заданного значения (функция) |