shared_ptr::reiniciar

Substitua recurso controlado.

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

Parâmetros

  • Other
    O tipo controlado pelo ponteiro argumento.

  • D
    O tipo do deleter.

  • ptr
    O ponteiro para copiar.

  • dtor
    Deleter para copiar.

Comentários

Todos os operadores decrementam a contagem de referência para o recurso atualmente propriedade *this e atribuir a propriedade do recurso nomeado pela sequência do operando para *this. Se a contagem de referência cai a zero, o recurso é liberado.Se um operador falhar, ele deixa *this inalterado.

Exemplo

 

// 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::tr1::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); 
    } 
 
*sp == 5 (bool)sp == false *sp == 10 *sp == 15

Requisitos

Cabeçalho:<memória>

Namespace: std::tr1

Consulte também

Referência

<memória>TR1)

Classe shared_ptr

shared_ptr::operador =