std::is_const
Материал из cppreference.com
| Определён в заголовочном файле <type_traits>
|
||
| template< class T > struct is_const; |
(начиная с C++11) | |
Если T является типом с квалификатором const или const volatile, то будет предоставлена константа-член value, которая будет равна true. Для всех остальных типов она будет равна false.
Содержание |
[править] Аргумент шаблона
| T | — | Тип для проверки |
[править] Вспомогательная шаблонная переменная
| template< class T > constexpr bool is_const_v = is_const<T>::value; |
(начиная с C++17) | |
Унаследован от std::integral_constant
Константы-члены
| value [static] |
true, если T является типом с квалификатором const, иначе false (public static константа-член) |
Функции-члены
| operator bool |
Преобразует объект в bool, возвращается value (public функция-член) |
| operator() (C++14) |
Возвращает value (public функция-член) |
Типы-члены
| Тип | Определение |
value_type
|
bool
|
type
|
std::integral_constant<bool, value> |
[править] Возможная реализация
template<class T> struct is_const : std::false_type {}; template<class T> struct is_const<const T> : std::true_type {}; |
[править] Пример
Запустить этот код
#include <iostream> #include <type_traits> int main() { std::cout << std::boolalpha; std::cout << std::is_const<int>::value << '\n'; // false std::cout << std::is_const<const int>::value << '\n'; // true std::cout << std::is_const<const int*>::value << '\n'; // false std::cout << std::is_const<int* const>::value << '\n'; // true std::cout << std::is_const<const int&>::value << '\n'; // false }
Вывод:
false true false true false
[править] См. также
| (C++11) |
Проверяет содержит ли тип в себе квалификатор volatile или нет (шаблон класса) |
| (library fundamentals TS) |
Шаблонная переменная, являющая псевдонимом для std::is_const::value (шаблонная переменная) |
| (C++17) |
Получает ссылку на константу его аргумента (шаблон функции) |

