[英]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.