Suppose I have a Linked List I created myself. It has its own destructor, which frees the memory. This Linked List does not overload new or delete.
Now, I'm trying to create an array of said linked lists (open hashing, if I understand correctly). Then I allocate the necessary memory inside the constructor of this open hashing class. The new operator being called inside the constructor is enough to correctly allocate the memory for the array, right? I'm not sure because I haven't overloaded new for the Linked List class.
Also, assuming my array of Linked Lists is called elements, could I just write "delete[] elements" in the destructor? Would that call the destructor for each element in the array and correctly free the memory?
Finally, if both my assumptions are correct (ie, I don't have to overload new and delete to use them with my custom class), what is the point of overloading such operators?
shared_ptr
orunique_prt
. both were introduced in c++11 STL <memory>. shared pointers will do book keeping of delete automatically. note for arrays default deleter provided byshared_ptr
calls delete, not delete[] therefore use lambda functionsstd::shared_ptr<int> p(new int[10], [](int* p) { delete[] p; });
orstd::shared_ptr<int> p(new int[10], std::default_delete<int[]>());
or using helper provided from unique_ptr which calls delete[]std::unique_ptr<int,void(*)(int*)> p(new int[10], [](int* p) { delete[] p; });
– katta