|  | Home | Libraries | People | FAQ | More | 
boost::interprocess::scoped_ptr
// In header: <boost/interprocess/smart_ptr/scoped_ptr.hpp> template<typename T, typename Deleter> class scoped_ptr : private Deleter { public: // types typedef T element_type; typedef Deleter deleter_type; typedef unspecified pointer; typedef pointer this_type::* unspecified_bool_type; // construct/copy/destruct explicit scoped_ptr(const pointer & = 0, const Deleter & = Deleter()); ~scoped_ptr(); // public member functions void reset(const pointer & = 0); void reset(const pointer &, const Deleter &); pointer release() noexcept; reference operator *() const noexcept; pointer & operator->() noexcept; const pointer & operator->() const noexcept; pointer & get() noexcept; const pointer & get() const noexcept; operator unspecified_bool_type() const noexcept; bool operator!() const noexcept; void swap(scoped_ptr &) noexcept; };
scoped_ptr stores a pointer to a dynamically allocated object. The object pointed to is guaranteed to be deleted, either on destruction of the scoped_ptr, or via an explicit reset. The user can avoid this deletion using release(). scoped_ptr is parameterized on T (the type of the object pointed to) and Deleter (the functor to be executed to delete the internal pointer). The internal pointer will be of the same pointer type as typename Deleter::pointer type (that is, if typename Deleter::pointer is offset_ptr<void>, the internal pointer will be offset_ptr<T>).
scoped_ptr 
        public
       construct/copy/destructexplicit scoped_ptr(const pointer & p = 0, const Deleter & d = Deleter());
Constructs a scoped_ptr, storing a copy of p(which can be 0) and d. Does not throw. 
~scoped_ptr();
If the stored pointer is not 0, destroys the object pointed to by the stored pointer. calling the operator() of the stored deleter. Never throws
scoped_ptr public member functionsvoid reset(const pointer & p = 0);
Deletes the object pointed to by the stored pointer and then stores a copy of p. Never throws
void reset(const pointer & p, const Deleter & d);
Deletes the object pointed to by the stored pointer and then stores a copy of p and a copy of d.
pointer release() noexcept;
Assigns internal pointer as 0 and returns previous pointer. This will avoid deletion on destructor
reference operator *() const noexcept;
Returns a reference to the object pointed to by the stored pointer. Never throws.
pointer & operator->() noexcept;
Returns the internal stored pointer. Never throws.
const pointer & operator->() const noexcept;
Returns the internal stored pointer. Never throws.
pointer & get() noexcept;
Returns the stored pointer. Never throws.
const pointer & get() const noexcept;
Returns the stored pointer. Never throws.
operator unspecified_bool_type() const noexcept;
Conversion to bool Never throws
bool operator!() const noexcept;
Returns true if the stored pointer is 0. Never throws.
void swap(scoped_ptr & b) noexcept;
Exchanges the internal pointer and deleter with other scoped_ptr Never throws.