临界区与互斥量的区别 为什么基类的析构函数定义为虚函数?
为什么基类的析构函数定义为虚函数?我们经常使用基类指针指向派生类对象,然后通过delete基类指针删除派生类对象。此时,为了确保派生类对象可以被完全析构函数,我们自然需要基类析构函数是一个虚函数。这样
为什么基类的析构函数定义为虚函数?
我们经常使用基类指针指向派生类对象,然后通过delete基类指针删除派生类对象。此时,为了确保派生类对象可以被完全析构函数,我们自然需要基类析构函数是一个虚函数。这样,在删除的时候会调用派生类析构函数,否则只调用基类析构函数,派生类不能完全析构函数出来的部分。
析构函数为什么是虚函数?
使用delete PA指向基类引用时,释放PA引用的内存,PA引用B object,为什么不调用B的析构函数呢?这里,由于是静态绑定,当B在编译时确定了它指向的函数时,它不会根据对象a来确定它指向的函数,这样,如果B申请内存资源,但不释放析构函数中的资源,就会导致内存泄漏。
仔细想想,这不是虚拟功能的原因吗?
添加了虚拟机制。编译时,虚拟机会自动将方法指向B的地址,通过设置机制可以找到B的析构函数。
为了改变这一点,有一个虚拟析构函数
只要基类的析构函数设置为virtual type,所有派生类都会自动将析构函数设置为virtual type,以确保不会因为没有调用析构函数而导致内存泄漏。