shared_ptr::~shared_ptr

Destroys a shared_ptr.

~shared_ptr();

Remarks

The destructor decrements the reference count for the resource currently owned by *this. If the reference count falls to zero, the resource is released.

Example

 

// std_tr1__memory__shared_ptr_destroy.cpp 
// compile with: /EHsc 
#include <memory> 
#include <iostream> 
 
struct deleter 
    { 
    void operator()(int *p) 
        { 
        delete p; 
        } 
    }; 
 
int main() 
    { 
    std::shared_ptr<int> sp1(new int(5)); 
    std::cout << "*sp1 == " << *sp1 << std::endl; 
    std::cout << "use count == " << sp1.use_count() << std::endl; 
 
     { 
    std::shared_ptr<int> sp2(sp1); 
    std::cout << "*sp2 == " << *sp2 << std::endl; 
    std::cout << "use count == " << sp1.use_count() << std::endl; 
     } 
 
// check use count after sp2 is destroyed 
    std::cout << "use count == " << sp1.use_count() << std::endl; 
 
    return (0); 
    } 
 
*sp1 == 5
use count == 1
*sp2 == 5
use count == 2
use count == 1

Requirements

Header: <memory>

Namespace: std

See Also

Reference

shared_ptr Class