- Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::weak_ptr::weak_ptr(3) | C++ Standard Libary | std::weak_ptr::weak_ptr(3) | 
NAME¶
std::weak_ptr::weak_ptr - std::weak_ptr::weak_ptr
Synopsis¶
 constexpr weak_ptr() noexcept; (1) (since C++11)
  
   weak_ptr( const weak_ptr& r ) noexcept; (2) (since C++11)
  
   template< class Y > (2) (since C++11)
  
   weak_ptr( const weak_ptr<Y>& r ) noexcept;
  
   template< class Y > (2) (since C++11)
  
   weak_ptr( const std::shared_ptr<Y>& r ) noexcept;
  
   weak_ptr( weak_ptr&& r ) noexcept; (3) (since C++11)
  
   template< class Y > (3) (since C++11)
  
   weak_ptr( weak_ptr<Y>&& r ) noexcept;
  
   Constructs new weak_ptr that potentially shares an object with r.
  
   1) Default constructor. Constructs empty weak_ptr.
  
   2) Constructs new weak_ptr which shares an object managed by r. If r manages
    no
  
   object, *this manages no object too. The templated overloads don't
    participate in
  
   the overload resolution unless Y* is implicitly convertible to T*
  
   , or Y is the type "array of N U" for some type U and some number
    N, and T is the
  
   type "array of unknown bound of (possibly cv-qualified) U"
  
   (since C++17).
  
   3) Move constructors. Moves a weak_ptr instance from r into *this. After
    this, r is
  
   empty and r.use_count() == 0. The templated overload doesn't participate in
    the
  
   overload resolution unless Y* is implicitly convertible to T*.
Parameters¶
r - a std::shared_ptr or std::weak_ptr that will be viewed by this std::weak_ptr
Notes¶
 Because the default constructor is constexpr, static
    std::weak_ptrs are initialized
  
   as part of static non-local initialization, before any dynamic non-local
  
   initialization begins. This makes it safe to use a std::weak_ptr in a
    constructor of
  
   any static object.
Example¶
// Run this code
  
   #include <iostream>
  
   #include <memory>
  
   struct Foo {};
  
   int main()
  
   {
  
   std::weak_ptr<Foo> w_ptr;
  
   {
  
   auto ptr = std::make_shared<Foo>();
  
   w_ptr = ptr;
  
   std::cout << "w_ptr.use_count() inside scope: " <<
    w_ptr.use_count() << '\n';
  
   }
  
   std::cout << "w_ptr.use_count() out of scope: " <<
    w_ptr.use_count() << '\n';
  
   std::cout << "w_ptr.expired() out of scope: "
  
   << std::boolalpha << w_ptr.expired() << '\n';
  
   }
Output:¶
 w_ptr.use_count() inside scope: 1
  
   w_ptr.use_count() out of scope: 0
  
   w_ptr.expired() out of scope: true
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   LWG 2315 C++11 move semantic was not enabled for weak_ptr enabled
See also¶
 operator= assigns the weak_ptr
  
   (public member function)
| 2024.06.10 | http://cppreference.com |