std::is_within_lifetime - cppreference.com (original) (raw)

| | | | | ---------------------------------------------------------------------------------- | | ------------- | | template< class T >consteval bool is_within_lifetime( const T* ptr ) noexcept; | | (since C++26) |

Determines whether the pointer ptr points to an object that is within its lifetime.

During the evaluation of an expression E as a core constant expression, a call to std::is_within_lifetime is ill-formed unless ptr points to an object

[edit] Parameters

[edit] Return value

true if pointer ptr points to an object that is within its lifetime; otherwise false.

[edit] Notes

Feature-test macro Value Std Feature
__cpp_lib_is_within_lifetime 202306L (C++26) Checking if a union alternative is active

[edit] Example

std::is_within_lifetime can be used to check whether a union member is active:

#include   // 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); }