shared_ptr::reset
Ersetzt die Ressource, die Eigentum ist.
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);
Parameter
Other
Der vom Argumentzeiger gesteuerte Typ.D
Der Deleter-Typ.ptr
Der zu kopierende Zeiger.dtor
Der Deleter zu kopieren.A
Der Zuweisungstyp.alloc
Die Zuweisung zu kopieren.
Hinweise
Alle Operatoren dekrementieren den Verweiszähler für die Ressource, die derzeit von *this gehört und weisen *this Besitz zu der Ressource, die von der Operandensequenz genannt wird. Wenn der Verweiszähler auf null liegt, wird die Ressource freigegeben. Wenn ein Operator fehlschlägt, können diese *this unverändert.
Beispiel
// 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);
}
Anforderungen
Header: <memory>
Namespace: std