Namespaces
Variants

std:: bad_weak_ptr

From cppreference.net
Memory management library
( exposition only* )
Allocators
Uninitialized memory algorithms
Constrained uninitialized memory algorithms
Memory resources
Uninitialized storage (until C++20)
( until C++20* )
( until C++20* )
( until C++20* )

Garbage collector support (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
(C++11) (until C++23)
Definido en el encabezado <memory>
class bad_weak_ptr ;
(desde C++11)

std::bad_weak_ptr es el tipo del objeto lanzado como excepción por los constructores de std::shared_ptr que toman std::weak_ptr como argumento, cuando el std::weak_ptr hace referencia a un objeto ya eliminado.

cpp/error/exception std-bad weak ptr-inheritance.svg

Diagrama de herencia

Contenidos

Funciones miembro

(constructor)
construye un nuevo objeto bad_weak_ptr
(función miembro pública)
operator=
reemplaza el objeto bad_weak_ptr
(función miembro pública)
what
devuelve la cadena explicativa
(función miembro pública)

std::bad_weak_ptr:: bad_weak_ptr

bad_weak_ptr ( ) noexcept ;
(1) (desde C++11)
bad_weak_ptr ( const bad_weak_ptr & other ) noexcept ;
(2) (desde C++11)

Construye un nuevo objeto bad_weak_ptr con una cadena de bytes terminada en nulo definida por la implementación que es accesible a través de what() .

1) Constructor por defecto.
2) Constructor de copia. Si * this y other tienen ambos tipo dinámico std::bad_weak_ptr entonces std:: strcmp ( what ( ) , other. what ( ) ) == 0 .

Parámetros

other - otro objeto de excepción a copiar

std::bad_weak_ptr:: operator=

bad_weak_ptr & operator = ( const bad_weak_ptr & other ) noexcept ;
(desde C++11)

Asigna los contenidos con los de other . Si * this y other ambos tienen tipo dinámico std::bad_weak_ptr 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_weak_ptr:: 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 <iostream>
#include <memory>
int main()
{
    std::shared_ptr<int> p1(new int(42));
    std::weak_ptr<int> wp(p1);
    p1.reset();
    try
    {
        std::shared_ptr<int> p2(wp);
    }
    catch (const std::bad_weak_ptr& e)
    {
        std::cout << e.what() << '\n';
    }
}

Salida posible:

std::bad_weak_ptr

Informes de defectos

Los siguientes informes de defectos que modifican el comportamiento se aplicaron retroactivamente a los estándares publicados anteriormente de C++.

DR Se aplica a Comportamiento publicado Comportamiento correcto
LWG 2376 C++11 llamar what en un bad_weak_ptr construido por defecto requería retornar "bad_weak_ptr" el valor de retorno está definido por la implementación

Véase también

(C++11)
puntero inteligente con semántica de propiedad compartida de objetos
(plantilla de clase)
(C++11)
referencia débil a un objeto gestionado por std::shared_ptr
(plantilla de clase)