| Defined in header <memory> | ||
|---|---|---|
class bad_weak_ptr; | (since C++11) |
std::bad_weak_ptr is the type of the object thrown as exceptions by the constructors of std::shared_ptr that take std::weak_ptr as the argument, when the std::weak_ptr refers to an already deleted object.
Inheritance diagram.
Member functions
constructs the bad_weak_ptr object (public member function) |
Inherited from std::exception
Member functions
| (destructor)
[virtual] | destructs the exception object (virtual public member function of std::exception) |
| [virtual] | returns an explanatory string (virtual public member function of std::exception) |
Example
#include <memory>
#include <iostream>
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';
}
}Output:
std::bad_weak_ptr
See also
| (C++11) | smart pointer with shared object ownership semantics (class template) |
| (C++11) | weak reference to an object managed by std::shared_ptr (class template) |
Please login to continue.