为什么析构函数要声明为虚函数

防止内训泄漏。
原因:如果在派生类中申请了内存空间,在析构函数对这块内存进行释放。假设基类中采用非虚析构函数,当删除基类指针指向派生类的对象时,就不会触发动态绑定,也不会调用派生类的析构函数。那么,派生类的内存空间得不到释放就会发生内存泄漏。

为什么不会触发动态绑定?
所谓的动态绑定的条件是:基类的指针或引用有可能指向不同的派生类的对象。对于非虚函数,执行时实际调用该函数的对象类型为该指针或引用的静态类型(基类类型);对于虚函数,执行时实际调用该函数的对象类型为该指针或引用的实际类型。

总结:
三种情况(构造函数和析构函数调用顺序):
1)基类的指针指向派生类的对象(有virtural)
构造(创建):先创建基类的对象,然后创建派生类的对象;
析构(释放):先释放派生类的对象,然后释放基类的对象;
2)基类的指针指向派生类的对象(无virtural)
构造(创建):先创建基类的对象,然后创建派生类的对象;
析构(释放):只释放基类的对象;
3)派生类的指针指向派生类的对象(有virtural)
构造(创建):先创建基类的对象,然后创建派生类的对象;
析构(释放):先释放派生类的对象,然后释放基类的对象;

猜你喜欢

转载自blog.csdn.net/QIJINGBO123/article/details/88119572
今日推荐