std::is_const
Материал из cppreference.com
<tbody>
</tbody>
| Определено в заголовочном файле <type_traits>
|
||
template< class T > struct is_const; |
(начиная с C++11) | |
std::is_const является UnaryTypeTrait.
Если T является const-квалифицированным типом (то есть const или const volatile), предоставляет константу-элемент value, равную true. Для любого другого типа value равна false.
Поведение программы, добавляющей специализации для std::is_const или std::is_const_v (начиная с C++17) не определено.
Параметры шаблона
| T | — | тип для проверки |
Шаблон вспомогательной переменной
<tbody> </tbody> template< class T > inline 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>
|
Примечание
Если T является ссылочным типом, то is_const<T>::value всегда равна false. Правильный способ проверить потенциально ссылочный тип на константность это удалить ссылку:
is_const<typename remove_reference<T>::type>.
Возможная реализация
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::is_const_v<int> << '\n' // false
<< std::is_const_v<const int> << '\n' // true
<< std::is_const_v<const int*> // false
<< " потому что сам указатель может быть изменён, но не int, на который он указывает\n"
<< std::is_const_v<int* const> // true
<< " потому что сам указатель не может быть изменён, а указанный int может\n"
<< std::is_const_v<const int&> << '\n' // false
<< std::is_const_v<std::remove_reference_t<const int&>> << '\n' // true
;
}
Вывод:
false
true
false потому что сам указатель может быть изменён, но не int, на который он указывает
true потому что сам указатель не может быть изменён, а указанный int может
false
true
Смотрите также
(C++11) |
проверяет, является ли тип volatile квалифицированным (шаблон класса) |
(C++17) |
получает ссылку на константу её аргумента (шаблон функции) |