std::chrono::ceil(std::chrono::duration)
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <chrono>
|
||
template <class ToDuration, class Rep, class Period> constexpr ToDuration ceil(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 ceil(const std::chrono::duration<Rep, Period>& d)
{
To t = std::chrono::duration_cast<To>(d);
if (t < d)
return t + To{1};
return t;
}
|
Пример
Запустить этот код
#include <iostream>
#include <chrono>
int main()
{
using namespace std::chrono_literals;
using Min = std::chrono::minutes;
std::cout
<< std::showpos
<< "ceil(+2.4min) = " << std::chrono::ceil<Min>(+2.4min).count() << "мин\n"
<< "ceil(-2.4min) = " << std::chrono::ceil<Min>(-2.4min).count() << "мин\n"
<< "ceil(+0.0min) = " << std::chrono::ceil<Min>(+0.0min).count() << "мин\n";
}
Вывод:
ceil(+2.4min) = +3мин
ceil(-2.4min) = -2мин
ceil(+0.0min) = +0мин
Смотрите также
(C++11) |
преобразует duration в другой duration с другим интервалом тиков (шаблон функции) |
(C++17) |
преобразует duration в другой, округляя в меньшую сторону (шаблон функции) |
(C++17) |
преобразует duration в другой, округляя до ближайшего, или до чётного в промежуточных случаях (шаблон функции) |
| преобразует time_point в другой, округляя в большую сторону (шаблон функции) | |
(C++11)(C++11) |
ближайшее целое число не меньшее заданного значения (функция) |