Namespaces
Variants

std:: is_null_pointer

From cppreference.net
Metaprogramming library
Type traits
Type categories
(C++11)
is_null_pointer
(C++11) ( DR* )
Type properties
(C++11)
(C++11)
(C++14)
(C++11) (deprecated in C++26)
(C++11) ( until C++20* )
(C++11) (deprecated in C++20)
(C++11)
Type trait constants
Metafunctions
(C++17)
Supported operations
Relationships and property queries
Type modifications
Type transformations
(C++11) (deprecated in C++23)
(C++11) (deprecated in C++23)
(C++11)
(C++11) ( until C++20* ) (C++17)

Compile-time rational arithmetic
Compile-time integer sequences
Определено в заголовочном файле <type_traits>
template < class T >
struct is_null_pointer ;
(начиная с C++11)

std::is_null_pointer является UnaryTypeTrait .

Проверяет, является ли T типом std::nullptr_t .

Предоставляет константу-член value , равную true , если T является типом std::nullptr_t , const std:: nullptr_t , volatile std:: nullptr_t , или const volatile std:: nullptr_t .

В противном случае, value равно false .

Если программа добавляет специализации для std::is_null_pointer или std::is_null_pointer_v (начиная с C++17) , поведение не определено.

Содержание

Параметры шаблона

T - тип для проверки

Шаблон вспомогательной переменной

template < class T >
constexpr bool is_null_pointer_v = is_null_pointer < T > :: value ;
(начиная с C++17)

Унаследовано от std:: integral_constant

Константы-члены

value
[static]
true если T является типом std::nullptr_t (возможно с cv-квалификаторами), false в противном случае
(публичная статическая константа-член)

Функции-члены

operator bool
преобразует объект в bool , возвращает value
(публичная функция-член)
operator()
(C++14)
возвращает value
(публичная функция-член)

Типы-члены

Тип Определение
value_type bool
type std:: integral_constant < bool , value >

Возможная реализация

template<class T>
struct is_null_pointer : std::is_same<std::nullptr_t, std::remove_cv_t<T>> {};

Примечания

std::is_pointer имеет значение false для std::nullptr_t поскольку это не встроенный указательный тип.

В libc++, std::is_null_pointer недоступен в режиме C++11.

Макрос тестирования возможностей Значение Стандарт Возможность
__cpp_lib_is_null_pointer 201309L (C++14)
(DR11)
std::is_null_pointer

Пример

#include <type_traits>
static_assert(std::is_null_pointer_v<decltype(nullptr)>);
static_assert(!std::is_null_pointer_v<int*>);
static_assert(!std::is_pointer_v<decltype(nullptr)>);
static_assert(std::is_pointer_v<int*>);
int main()
{
}

Отчеты о дефектах

Следующие отчеты об изменениях поведения, влияющие на дефекты, были применены ретроактивно к ранее опубликованным стандартам C++.

DR Применяется к Поведение в опубликованной версии Корректное поведение
LWG 2247 C++11 отсутствовал трейт типа для обнаружения std::nullptr_t добавлен

Смотрите также

(C++11)
проверяет, является ли тип void
(шаблон класса)
(C++11)
проверяет, является ли тип массивом
(шаблон класса)
(C++11)
проверяет, является ли тип указателем
(шаблон класса)
(C++11)
проверяет, является ли тип перечислением
(шаблон класса)
(C++11)
проверяет, является ли тип объединением
(шаблон класса)
(C++11)
проверяет, является ли тип классом (не объединением)
(шаблон класса)
проверяет, является ли тип функцией
(шаблон класса)
(C++11)
проверяет, является ли тип объектным типом
(шаблон класса)