I’ve been thinking about the possible use of delete this in c++, and I’ve seen one use.
Because you can say delete this only when an object is on heap, I can make the destructor private and stop objects from being created on stack altogether. In the end I can just delete the object on heap by saying delete this in a random public member function that acts as a destructor. My questions:
1) Why would I want to force the object to be made on the heap instead of on the stack?
2) Is there another use of delete this apart from this? (supposing that this is a legitimate use of it 🙂 )
Any scheme that uses
delete thisis somewhat dangerous, since whoever called the function that does that is left with a dangling pointer. (Of course, that’s also the case when you delete an object normally, but in that case, it’s clear that the object has been deleted). Nevertheless, there are somewhat legitimate cases for wanting an object to manage its own lifetime.It could be used to implement a nasty, intrusive reference-counting scheme. You would have functions to “acquire” a reference to the object, preventing it from being deleted, and then “release” it once you’ve finished, deleting it if noone else has acquired it, along the lines of:
I would prefer to use
std::shared_ptrfor this purpose, since it’s thread-safe, exception-safe, works for any type without needing any explicit support, and prevents access after deleting.More usefully, it could be used in an event-driven system, where objects are created, and then manage themselves until they receive an event that tells them that they’re no longer needed: