std::in_range
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <utility>
|
||
template< class R, class T > constexpr bool in_range( T t ) noexcept; |
(начиная с C++20) | |
Возвращает true, если значение t находится в диапазоне значений, которые могут быть представлены в R, то есть если t может быть преобразован в R без потери данных.
Это ошибка времени компиляции, если либо T, либо R не являются целочисленным типом со знаком или без знака (включая стандартный целочисленный тип и расширенный целочисленный тип).
Параметры
| t | — | значение для проверки |
Возвращаемое значение
true, если значение t может быть представлено в R, false иначе.
Возможная реализация
template< class R, class T >
constexpr bool in_range( T t ) noexcept
{
return std::cmp_greater_equal(t, std::numeric_limits<R>::min()) &&
std::cmp_less_equal(t, std::numeric_limits<R>::max());
}
|
Примечание
Эту функцию нельзя использовать с перечислениями (включая std::byte), char, char8_t, char16_t, char32_t, wchar_t и bool.
| Макрос Тестирования функциональности | Значение | Стандарт | Функциональность |
|---|---|---|---|
__cpp_lib_integer_comparison_functions |
202002L |
(C++20) | Целочисленные функции сравнения |
Пример
Запустить этот код
#include <iostream>
#include <utility>
int main()
{
std::cout << std::boolalpha;
std::cout << std::in_range<std::size_t>(-1) << '\n';
std::cout << std::in_range<std::size_t>(42) << '\n';
}
Вывод:
false
true
Смотрите также
(C++20) |
возвращает меньшее из заданных значений (ниблоид) |
(C++20) |
возвращает большее из заданных значений (ниблоид) |
(C++20) |
фиксирует значение между парой граничных значений (ниблоид) |
(C++20) |
функция линейной интерполяции (функция) |