std:: is_pointer_interconvertible_base_of
|
Definiert im Header
<type_traits>
|
||
|
template
<
class
Base,
class
Derived
>
struct is_pointer_interconvertible_base_of ; |
(seit C++20) | |
Wenn
Derived
eindeutig von
Base
abgeleitet ist und jedes
Derived
Objekt
zeiger-interkonvertierbar
mit seinem
Base
Unterobjekt ist, oder wenn beide dieselbe Nicht-Union-Klasse sind (in beiden Fällen unter Ignorierung von CV-Qualifizierern), liefert die Member-Konstante
value
den Wert
true
. Andernfalls ist
value
false
.
Wenn sowohl
Base
als auch
Derived
Nicht-Union-Klassentypen sind und sie nicht denselben Typ haben (unter Ignorierung von CV-Qualifizierern),
Derived
muss ein
vollständiger Typ
sein; andernfalls ist das Verhalten undefiniert.
Wenn das Programm Spezialisierungen für
std::is_pointer_interconvertible_base_of
oder
std::is_pointer_interconvertible_base_of_v
hinzufügt, ist das Verhalten undefiniert.
Inhaltsverzeichnis |
Hilfsvariablen-Template
|
template
<
class
Base,
class
Derived
>
inline
constexpr
bool
is_pointer_interconvertible_base_of_v
=
|
(seit C++20) | |
Geerbt von std:: integral_constant
Member-Konstanten
|
value
[static]
|
true
wenn
Derived
eindeutig von
Base
abgeleitet ist und jedes
Derived
Objekt
zeiger-konvertierbar
mit seinem
Base
Subobjekt ist, oder wenn beide dieselbe Nicht-Union-Klasse sind (in beiden Fällen unter Ignorierung von CV-Qualifizierern),
false
andernfalls
(öffentliche statische Member-Konstante) |
Member-Funktionen
|
operator bool
|
konvertiert das Objekt zu
bool
, gibt
value
zurück
(öffentliche Member-Funktion) |
|
operator()
(C++14)
|
gibt
value
zurück
(öffentliche Member-Funktion) |
Member-Typen
| Typ | Definition |
value_type
|
bool |
type
|
std:: integral_constant < bool , value > |
Hinweise
std
::
is_pointer_interconvertible_base_of_v
<
T, U
>
kann
true
sein, selbst wenn
T
eine private oder protected Basisklasse von
U
ist.
Sei
-
Usei ein vollständiger Objekttyp, -
Tsei ein vollständiger Objekttyp mit CV-Qualifikation nicht geringer alsU, -
usei ein beliebiger gültiger Lvalue vonU,
reinterpret_cast < T & > ( u ) hat immer ein wohldefiniertes Ergebnis, wenn std :: is_pointer_interconvertible_base_of_v < T, U > gleich true ist.
Wenn
T
und
U
nicht denselben Typ haben (unter Ignorierung von CV-Qualifizierern) und
T
eine zeigerinterkonvertierbare Basisklasse von
U
ist, dann sind sowohl
std::
is_standard_layout_v
<
T
>
als auch
std::
is_standard_layout_v
<
U
>
true
.
Wenn
T
ein Standard-Layout-Klassentyp ist, dann sind alle Basisklassen von
T
(falls vorhanden) zeigerinterkonvertierbare Basisklassen von
T
.
| Feature-Test Makro | Wert | Standard | Funktion |
|---|---|---|---|
__cpp_lib_is_pointer_interconvertible
|
201907L
|
(C++20) |
Zeiger-Interkonvertierbarkeits-Traits:
|
Beispiel
#include <type_traits> struct Foo {}; struct Bar {}; class Baz : Foo, public Bar { int x; }; class NonStdLayout : public Baz { int y; }; static_assert(std::is_pointer_interconvertible_base_of_v<Bar, Baz>); static_assert(std::is_pointer_interconvertible_base_of_v<Foo, Baz>); static_assert(not std::is_pointer_interconvertible_base_of_v<Baz, NonStdLayout>); static_assert(std::is_pointer_interconvertible_base_of_v<NonStdLayout, NonStdLayout>); int main() {}
Siehe auch
|
(C++11)
|
prüft, ob ein Typ eine Basis eines anderen Typs ist
(Klassen-Template) |
|
(C++11)
|
prüft, ob ein Typ ein Klassentyp (aber kein Union-Typ) ist und keine nicht-statischen Datenelemente besitzt
(Klassen-Template) |
|
(C++11)
|
prüft, ob ein Typ ein
Standard-Layout
Typ ist
(Klassen-Template) |