std:: bad_variant_access
|
Definido en el encabezado
<variant>
|
||
|
class
bad_variant_access
:
public
std::
exception
|
(desde C++17) | |
std::bad_variant_access
es el tipo de excepción lanzada en las siguientes situaciones:
- std::get (std::variant) llamado con un índice o tipo que no coincide con la alternativa actualmente activa.
-
std::visitllamado para visitar unvariantque esvalueless_by_exception.
|
(desde C++26) |
Todas las funciones miembro de
std::bad_variant_access
son
constexpr
: es posible crear y utilizar objetos
std::bad_variant_access
en la evaluación de una expresión constante.
Sin embargo, los objetos
|
(since C++26) |
Contenidos |
Funciones miembro
|
(constructor)
|
construye un nuevo objeto
bad_variant_access
(función miembro pública) |
|
operator=
|
reemplaza el objeto
bad_variant_access
(función miembro pública) |
|
what
|
devuelve la cadena explicativa
(función miembro pública) |
std::bad_variant_access:: bad_variant_access
|
bad_variant_access
(
)
noexcept
;
|
(1) |
(desde C++17)
(constexpr desde C++26) |
|
bad_variant_access
(
const
bad_variant_access
&
other
)
noexcept
;
|
(2) |
(desde C++17)
(constexpr desde C++26) |
Construye un nuevo objeto
bad_variant_access
con una cadena de bytes terminada en nulo definida por la implementación, accesible a través de
what()
.
std::bad_variant_access
entonces
std::
strcmp
(
what
(
)
, other.
what
(
)
)
==
0
.
Parámetros
| other | - | otro objeto de excepción a copiar |
std::bad_variant_access:: operator=
|
bad_variant_access
&
operator
=
(
const
bad_variant_access
&
other
)
noexcept
;
|
(desde C++17)
(constexpr desde C++26) |
|
Asigna los contenidos con los de
other
. Si
*
this
y
other
ambos tienen tipo dinámico
std::bad_variant_access
entonces
std::
strcmp
(
what
(
)
, other.
what
(
)
)
==
0
después de la asignación.
Parámetros
| other | - | otro objeto de excepción con el cual asignar |
Valor de retorno
* this
std::bad_variant_access:: what
|
virtual
const
char
*
what
(
)
const
noexcept
;
|
(desde C++17)
(constexpr desde C++26) |
|
Devuelve la cadena explicativa.
Valor de retorno
Puntero a una cadena terminada en nulo definida por la implementación con información explicativa. La cadena es adecuada para conversión y visualización como std::wstring . Se garantiza que el puntero es válido al menos hasta que se destruye el objeto de excepción del cual se obtiene, o hasta que se llama a una función miembro no constante (por ejemplo, el operador de asignación de copia) en el objeto de excepción.
|
La cadena devuelta está codificada con la codificación literal ordinaria durante la evaluación constante. |
(desde C++26) |
Notas
Las implementaciones pueden, pero no están obligadas a, sobrescribir
what()
.
Heredado de std:: exception
Funciones miembro
|
[virtual]
|
destruye el objeto de excepción
(función miembro pública virtual de
std::exception
)
|
|
[virtual]
|
devuelve una cadena explicativa
(función miembro pública virtual de
std::exception
)
|
Notas
| Macro de prueba de características | Valor | Std | Característica |
|---|---|---|---|
__cpp_lib_constexpr_exceptions
|
202502L
|
(C++26) |
constexpr
std::bad_variant_access
|
Ejemplo
#include <iostream> #include <variant> int main() { std::variant<int, float> v; v = 12; try { std::get<float>(v); } catch (const std::bad_variant_access& e) { std::cout << e.what() << '\n'; } }
Salida posible:
bad_variant_access
Véase también
|
(C++17)
|
lee el valor del variant dado el índice o el tipo (si el tipo es único), lanza una excepción en caso de error
(plantilla de función) |
|
(C++17)
|
llama al funtor proporcionado con los argumentos contenidos en uno o más
variant
s
(plantilla de función) |
|
(C++26)
|
llama al funtor proporcionado con el argumento contenido en el
variant
(función miembro pública) |
|
(C++17)
|
excepción que indica acceso verificado a un optional que no contiene un valor
(clase) |
|
(C++23)
|
excepción que indica acceso verificado a un
expected
que contiene un valor inesperado
(plantilla de clase) |