Partager via


shared_ptr::reset

Ressource propre Repositionne.

void reset();
template<class Other>
    void reset(Other *ptr;);
template<class Other, class D>
    void reset(Other *ptr, D dtor);
template<class Other, class D, class A>
    void reset(Other *ptr, D dtor, A alloc);

Paramètres

  • Other
    Le type contrôlé par le pointeur d'argument.

  • D
    Le type de suppression.

  • ptr
    Le pointeur à copier.

  • dtor
    La suppression à copier.

  • A
    Le type de l'allocateur.

  • alloc
    l'allocateur à copier.

Notes

Tous les opérateurs décrémentent le décompte de références pour la ressource actuel possédée par *this et assignez la propriété de la ressource nommée par la séquence d'opérande à *this.Si le décompte de références se situe à zéro, la ressource est libérée.Si un opérateur échoue elle permet *this inchangé.

Exemple

 

// std_tr1__memory__shared_ptr_reset.cpp 
// compile with: /EHsc 
#include <memory> 
#include <iostream> 
 
struct deleter 
    { 
    void operator()(int *p) 
        { 
        delete p; 
        } 
    }; 
 
int main() 
    { 
    std::shared_ptr<int> sp(new int(5)); 
 
    std::cout << "*sp == " << std::boolalpha 
        << *sp << std::endl; 
 
    sp.reset(); 
    std::cout << "(bool)sp == " << std::boolalpha 
        << (bool)sp << std::endl; 
 
    sp.reset(new int(10)); 
    std::cout << "*sp == " << std::boolalpha 
        << *sp << std::endl; 
 
    sp.reset(new int(15), deleter()); 
    std::cout << "*sp == " << std::boolalpha 
        << *sp << std::endl; 
 
    return (0); 
    } 
 
  

Configuration requise

en-tête : <memory>

l'espace de noms : DST

Voir aussi

Référence

shared_ptr Class

shared_ptr::operator=