虚拟解构器-内存泄漏

Virtual deconstructor - Memory leak

本文关键字:内存 泄漏 虚拟      更新时间:2023-10-16

现在我们必须创建class X(作为基类)和class Y(作为派生类)。它们都使用整数指针来保存不同大小的分配。

class X
{
  int *p;
  public:
         X() {p=new int[2];}
         ~X() {delete[] p;}
};
class Y : public X {
  int *q;
  public:
         Y() {q=new int[4];}
         ~Y() {delete[] q;}
};

让我们在一个简单的循环中尝试一下:

for(int i=0;i<8;i++){X *ptr =new Y; delete ptr;}

内存泄漏的原因是什么?我们能做些什么来修复它?

此循环的每次执行

for(int i=0;i<8;i++){X *ptr =new Y; delete ptr;}

您的程序首先创建一个大小为2(2*4=8个已分配字节)的整数指针,然后创建一个尺寸为4的整数指针(4*4=16个已分配的字节)但只删除第一个。因此,对于每个循环,它都会泄漏16个字节,因为您无法访问派生类Y中的解构器。

它被称为由于基类中缺少虚拟解构器而导致的内存泄漏。当您在类X virtual中制作解构器时,编译器将能够删除Y型指针。所以你必须更改这个陈述

~X() {delete[] p;}

进入这个:

virtual ~X() {delete[] p;}