I have a class which has an element
std::list<boost::reference_wrapper<polygonType> > m_children;
When an object is created out of this class, i store all the children of that object as reference in this variable. What I wanted to do is, when the destructor of the object is called, I wanted the destructor of the children to be called to.
This basically comes down to some of the design decisions I made and how I want them fixed.
Is that an automatic behavior in this case?
No. Storing a reference_wrapper
is equivalent to storing a raw pointer. In fact, there's no good reason for storing reference_wrapper
rather than polygonType*
here.
If I want them to not be deleted what do I need to do?
Store pointers (or reference_wrapper
, if you insist on obfuscation). It would probably be more efficient to use vector
rather than list
:
std::vector<polygonType*> children;
You must be careful that whatever is responsible for destroying the children doesn't leave dangling pointers here. You might consider managing them with shared pointers, and storing weak pointers in the list, to ensure that doesn't happen.
If I want them deleted what do I need to do ?
If polygonType
is a concrete type, then you might store the children directly in the list. In this case, list
may be the better choice, since it will never copy or move the objects it contains:
std::list<polygonType> children;
If it's a polymorphic base class, so that you can't store the objects directly, then store smart pointers. Again, vector
is probably a better choice than list
if you're storing pointers rather than objects:
std::vector<std::unique_ptr<polygonType>> children;
If you're stuck with a pre-2011 library, you might use boost::shared_ptr
rather than std::unique_ptr
; or perhaps a Boost pointer container.