std:: bad_function_call
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
| Old binders and adaptors | ||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
|
|||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||||
|
Definido en el encabezado
<functional>
|
||
|
class
bad_function_call
;
|
||
std::bad_function_call
es el tipo de excepción lanzada por
std::function::operator()
si el envoltorio de función no tiene un objetivo.
Diagrama de herencia
Contenidos |
Funciones miembro
|
(constructor)
|
construye un nuevo objeto
bad_function_call
(función miembro pública) |
|
operator=
|
reemplaza el objeto
bad_function_call
(función miembro pública) |
|
what
|
devuelve la cadena explicativa
(función miembro pública) |
std::bad_function_call:: bad_function_call
|
bad_function_call
(
)
noexcept
;
|
(1) | (desde C++11) |
|
bad_function_call
(
const
bad_function_call
&
other
)
noexcept
;
|
(2) | (desde C++11) |
Construye un nuevo objeto
bad_function_call
con una cadena de bytes terminada en nulo definida por la implementación que es accesible a través de
what()
.
std::bad_function_call
entonces
std::
strcmp
(
what
(
)
, other.
what
(
)
)
==
0
.
Parámetros
| other | - | otro objeto de excepción a copiar |
std::bad_function_call:: operator=
|
bad_function_call
&
operator
=
(
const
bad_function_call
&
other
)
noexcept
;
|
(desde C++11) | |
Asigna los contenidos con los de
other
. Si
*
this
y
other
ambos tienen tipo dinámico
std::bad_function_call
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_function_call:: what
|
virtual
const
char
*
what
(
)
const
noexcept
;
|
(desde C++11) | |
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 será válido al menos hasta que se destruya el objeto de excepción del cual se obtuvo, o hasta que se llame a una función miembro no constante (por ejemplo, el operador de asignación de copia) en el objeto de excepción.
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
)
|
Ejemplo
#include <functional> #include <iostream> int main() { std::function<int()> f = nullptr; try { f(); } catch (const std::bad_function_call& e) { std::cout << e.what() << '\n'; } }
Salida posible:
bad function call
Informes de defectos
Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares de C++ publicados anteriormente.
| DR | Aplicado a | Comportamiento publicado | Comportamiento correcto |
|---|---|---|---|
| LWG 2233 | C++11 |
what()
siempre retornaba la misma cadena
explicativa que std::exception::what() |
retorna su propia
cadena explicativa |
Véase también
|
(C++11)
|
contenedor copiable de cualquier objeto invocable con constructor de copia
(plantilla de clase) |