std::is_within_lifetime
Von cppreference.com
| Definiert in der Kopfdatei <type_traits> |
||
| template< class T > consteval bool is_within_lifetime( const T* ptr ) noexcept; |
(seit C++26) | |
Ermittelt, ob der Zeiger ptr auf ein Objekt zeigt, das sich innerhalb seiner Lebensdauer befindet.
Während der Auswertung eines Ausdrucks E als Kern-Konstantausdruck ist ein Aufruf von std::is_within_lifetime ill-formed, es sei denn, ptr zeigt auf ein Objekt
- das in Konstantausdrücken verwendbar ist, oder
- dessen vollständiges Objekt innerhalb von E begonnen hat.
Inhalt |
[bearbeiten] Parameter
| p | - | Zu prüfender Zeiger |
[bearbeiten] Rückgabewert
true, wenn der Zeiger ptr auf ein Objekt zeigt, das sich innerhalb seiner Lebensdauer befindet; andernfalls false.
[bearbeiten] Hinweise
| Feature-Test-Makro | Wert | Std | Feature |
|---|---|---|---|
__cpp_lib_is_within_lifetime |
202306L |
(C++26) | Prüfen, ob eine Union-Alternative aktiv ist |
[bearbeiten] Beispiel
std::is_within_lifetime kann verwendet werden, um zu prüfen, ob ein Union-Mitglied aktiv ist
Führen Sie diesen Code aus
#include <type_traits> // an optional boolean type occupying only one byte, // assuming sizeof(bool) == sizeof(char) struct optional_bool { union { bool b; char c; }; // assuming the value representations for true and false // are distinct from the value representation for 2 constexpr optional_bool() : c(2) {} constexpr optional_bool(bool b) : b(b) {} constexpr auto has_value() const -> bool { if consteval { return std::is_within_lifetime(&b); // during constant evaluation, // cannot read from c } else { return c != 2; // during runtime, must read from c } } constexpr auto operator*() -> bool& { return b; } }; int main() { constexpr optional_bool disengaged; constexpr optional_bool engaged(true); static_assert(!disengaged.has_value()); static_assert(engaged.has_value()); static_assert(*engaged); }