std::is_null_pointer
Von cppreference.com
| Definiert in der Kopfdatei <type_traits> |
||
| template< class T > struct is_null_pointer; |
(seit C++11) | |
std::is_null_pointer ist ein UnaryTypeTrait.
Prüft, ob T der Typ std::nullptr_t ist.
Stellt die Member-Konstante value bereit, die gleich true ist, wenn T der Typ std::nullptr_t ist, const std::nullptr_t, volatile std::nullptr_t oder const volatile std::nullptr_t ist.
Andernfalls ist value gleich false.
Wenn das Programm Spezialisierungen für std::is_null_pointer hinzufügt oder std::is_null_pointer_v(seit C++17), ist das Verhalten undefiniert.
Inhalt |
[bearbeiten] Template-Parameter
| T | - | ein zu prüfender Typ |
[bearbeiten] Hilfsvariablen-Template
| template< class T > constexpr bool is_null_pointer_v = is_null_pointer<T>::value; |
(seit C++17) | |
Abgeleitet von std::integral_constant
Member-Konstanten
| value [static] |
true, wenn T der Typ std::nullptr_t ist (möglicherweise cv-qualifiziert), false andernfalls(öffentliche statische Member-Konstante) |
Memberfunktionen
| operator bool |
konvertiert das Objekt zu bool, gibt value zurück (öffentliche Memberfunktion) |
| operator() (C++14) |
gibt value zurück (öffentliche Memberfunktion) |
Membertypen
| Typ | Definition |
value_type
|
bool |
type
|
std::integral_constant<bool, value> |
[bearbeiten] Mögliche Implementierung
template<class T> struct is_null_pointer : std::is_same<std::nullptr_t, std::remove_cv_t<T>> {}; |
[bearbeiten] Anmerkungen
std::is_pointer ist false für std::nullptr_t, da es kein eingebauter Zeigertyp ist.
In libc++, std::is_null_pointer ist im C++11-Modus nicht verfügbar.
| Feature-Test-Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_is_null_pointer |
201309L |
(C++14) (DR11) |
std::is_null_pointer
|
[bearbeiten] Beispiel
Führen Sie diesen Code aus
#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() { }
[bearbeiten] Fehlerberichte
Die folgenden Verhaltensändernden Fehlerberichte wurden rückwirkend auf zuvor veröffentlichte C++-Standards angewendet.
| DR | angewendet auf | Verhalten wie veröffentlicht | Korrigiertes Verhalten |
|---|---|---|---|
| LWG 2247 | C++11 | dem Typ-Trait für die Erkennung von std::nullptr_t fehlte | hinzugefügt |
[bearbeiten] Siehe auch
| (C++11) |
prüft, ob ein Typ void ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Arraytyp ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Zeigertyp ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Aufzählungstyp ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Union-Typ ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Nicht-Union-Klassentyp ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Funktionstyp ist (Klassenvorlage) |
| (C++11) |
prüft, ob ein Typ ein Objekttyp ist (Klassenvorlage) |