table of contents
        
      
      
    - Tumbleweed 2024.07.05-1.3
 - Leap-16.0
 - Leap-15.6
 
| std::enable_shared_from_this::shared_from_this(3) | C++ Standard Libary | std::enable_shared_from_this::shared_from_this(3) | 
NAME¶
std::enable_shared_from_this::shared_from_this - std::enable_shared_from_this::shared_from_this
Synopsis¶
 std::shared_ptr<T> shared_from_this(); (1) (since
    C++11)
  
   std::shared_ptr<T const> shared_from_this() const; (2) (since
    C++11)
  
   Returns a std::shared_ptr<T> that shares ownership of *this with all
    existing
  
   std::shared_ptr that refer to *this.
  
   Effectively executes std::shared_ptr<T>(weak_this), where weak-this is
    the
  
   exposition-only mutable std::weak_ptr<T> member of
    enable_shared_from_this.
Return value¶
 std::shared_ptr<T> that shares ownership of *this with
    pre-existing
  
   std::shared_ptrs.
Exceptions¶
 If shared_from_this is called on an object that is not previously
    shared by
  
   std::shared_ptr, std::bad_weak_ptr is thrown (by the shared_ptr constructor
    from a
  
   default-constructed weak-this).
Example¶
// Run this code
  
   #include <iostream>
  
   #include <memory>
  
   struct Foo : public std::enable_shared_from_this<Foo>
  
   {
  
   Foo() { std::cout << "Foo::Foo\n"; }
  
   ~Foo() { std::cout << "Foo::~Foo\n"; }
  
   std::shared_ptr<Foo> getFoo() { return shared_from_this(); }
  
   };
  
   int main()
  
   {
  
   Foo *f = new Foo;
  
   std::shared_ptr<Foo> pf1;
  
   {
  
   std::shared_ptr<Foo> pf2(f);
  
   pf1 = pf2->getFoo(); // shares ownership of object with pf2
  
   }
  
   std::cout << "pf2 is gone\n";
  
   }
Output:¶
 Foo::Foo
  
   pf2 is gone
  
   Foo::~Foo
  
   Defect reports
  
   The following behavior-changing defect reports were applied retroactively to
  
   previously published C++ standards.
  
   DR Applied to Behavior as published Correct behavior
  
   calling shared_from_this on an
  
   LWG 2529 C++11 unshared object was undefined std::bad_weak_ptr is thrown
  
   behavior
See also¶
 shared_ptr smart pointer with shared object ownership semantics
  
   (C++11) (class template)
| 2024.06.10 | http://cppreference.com |