繁体   English   中英

在C ++中为数组正确分配和释放内存

[英]Correct allocate and free memory for arrays in C++

我正在处理动态数组。 函数empty_matrix()创建一个表示矩阵的新数组。 delete_matrix()释放为矩阵分配的所有内存。

如果我调用add(add(a, b), c)我是否在函数example()出现内存泄漏? 在函数add(...)分配的内存会发生什么? 我必须释放它吗? 我应该在哪里做?

 matrix empty_matrix(int dim) {
 matrix m;
 m.dim = dim;
 m.data = new int*[dim];
 for (int i = 0; i < dim; i++)
  m.data[i] = new int[dim];

 return m;
}

void delete_matrix(matrix m) {
 for (int i = 0; i < dim; i++)
  delete [] m.data[i];
 delete [] m.data;
}

matrix add(matrix a, matrix b) {
 matrix c = empty_matrix(a.dim);
 for (int i = 0; i < a.dim; i++)
  for (int j = 0; j < a.dim; j++)
   c.data[i][j] = a.data[i][j] + b.data[i][j];

 return c;
}

void example() {
 matrix a = empty_matrix(100);
 matrix b = empty_matrix(100);
 matrix c = empty_matrix(100);

 // some modifications of a, b and c
 // ...

 matrix d = add(add(a, b), c);
 print_matrix(d);

 delete_matrix(a);
 delete_matrix(b);
 delete_matrix(c);
 delete_matrix(d);
} 

应该做的是使用面向对象/ RAII。 您的矩阵类的数据成员应该是私有的,并且它的内存应该在构造函数中分配,并在析构函数中释放。 这样,您就不必担心内存泄漏。

例如...

class matrix
{
public:
      typedef int element_type;
      matrix(int dimension)
          :data_(new element_type[dimension*dimension])
      {

      }  
      //Do define your copy-constructor and assignment operators
      ~matrix()
      {
         delete [] data_;
      } 

private:
      element_type* data_;
};

当然,如果这是家庭作业,这一切。 如果不是,那么在这种情况下你应该避免使用数组。 使用std::vector s

是的,您必须释放任何empty_matrix的结果或使用delete_matrix add调用。 你正在泄漏内存,因为你没有释放最里面的add调用的矩阵。

在代码中,一个delete[]应该只有一个new delete ,一个delete[]应该有一个new[] 这是最重要的原则。

因此,如果函数add创建了一个新矩阵,则需要在某处删除它。


另外, empty_matrix应该是matrix类的构造函数,而delete_matrix应该是它的destuctor。

您还可以使用std::vector替换data ,并且您的内存处理将更加自动化,从而使您免于计算new s和delete s的必要性。

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM