Пространства имён
Варианты
Действия

std::in_range

Материал из cppreference.com
 
 
Библиотека утилит
Языковая поддержка
Поддержка типов (базовые типы, RTTI)
Макросы тестирования функциональности библиотеки (C++20)    
Управление динамической памятью
Программные утилиты
Поддержка сопрограмм (C++20)
Вариативные функции
Трёхстороннее сравнение (C++20)
(C++20)
(C++20)(C++20)(C++20)(C++20)(C++20)(C++20)
Общие утилиты
Дата и время
Функциональные объекты
Библиотека форматирования (C++20)
(C++11)
Операторы отношения (устарело в C++20)
Целочисленные функции сравнения
(C++20)(C++20)(C++20)    
(C++20)
Операции обмена и типа
(C++14)
(C++11)
(C++11)
(C++11)
(C++17)
Общие лексические типы
(C++11)
(C++17)
(C++17)
(C++17)
(C++11)
(C++17)
(C++23)
Элементарные преобразования строк
(C++17)
(C++17)
 
<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)
функция линейной интерполяции
(функция) [править]