std::is_within_lifetime
De cppreference.com
| Definido en el archivo de encabezado <type_traits>
|
||
template< class T >
consteval bool is_within_lifetime( const T* ptr ) noexcept;
|
(desde C++26) | |
Determina si el puntero ptr apunta a un objeto que está dentro de su vida.
Durante la evaluación de una expresión E como una expresión constante central, una llamada a std::is_within_lifetime es malformada a menos que ptr apunte a un objeto
- que es utilizable en expresiones constantes, o
- cuya vida completa del objeto comenzó dentro de
E.
Parámetros
| ptr | - | Puntero a detectar. |
Valor de retorno
true si el puntero ptr apunta a un objeto que está dentro de su vida; de lo contrario, false.
Notas
| Macro de Prueba de característica | Valor | Estándar | Comentario |
|---|---|---|---|
__cpp_lib_is_within_lifetime |
202306L |
(C++26) | Comprueba si una alternativa de unión está activa. |
Ejemplo
std::is_within_lifetime se puede usar para comprobar si un miembro de unión está activo:
Ejecuta este código
#include <type_traits>
// un tipo booleano opcional que ocupa solo un byte,
// asumiendo que sizeof(bool) == sizeof(char)
struct optional_bool
{
union { bool b; char c; };
// asumiendo que las representaciones de valor para true y false
// son distintas de la representación de valor para 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); // durante la evaluación constante,
// no se puede leer desde c
}
else
{
return c != 2; // durante el tiempo de ejecución, se debe leer desde 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);
}