I have a situation that looks like the following code:
#include
class A
{
public:
A() { std::cout << \"A created!\" << std::end
If you apply operator "delete" to base class pointer, destructor MUST be virtual (existence of other virtual methods does not matter). For instance, in case of multiple inheritance "delete" operator applied to base class pointer will cause memory fault since compiler doesn't even know were the memory occupied by derived object begins.
As a rule of thumb, if any of your methods are virtual, the destructor must also be virtual. If it isn't, the declared type of a variable decides which destructor gets called, which is almost never what you want. 99.9% of all cases, you want the destructor from the runtime type.
Is this possible in its destructor or do I have to implement a virtual Destroy() method or something like that?
Make destructor of A virtual.
virtual ~A() { std::cout << "A destroyed!" << std::endl; }
If your class have virtual methods, it should use virtual destructor. At least some compilers will complain if you aren't using virtual destructor in class with virtual methods.