我在教育目的这样做。 这样的想法: 我有类Array。我在类Darray中继承它,并添加必要的维度
它喜欢这样:
的main.cpp
int main(int argc, char *argv[])
{
Array obj;
obj.output();
DArray obj2;
obj2.output();
return 0;
}
标题
class Array
{
public:
int *x,sizem; //одно измерение, массив
// можно объявить здесь как **x , но это не то
Array();
~Array();
virtual void output();
};
class DArray:public Array
{
public:
int **z;
int sizen;
DArray();
~DArray();
virtual void output();
};
realisation.cpp
Array::Array()
{
sizem=5;
x=new int[sizem];
for(int i=0;i<sizem;i++)
x[i]=i;
}
Array::~Array()
{
delete []x;
}
void Array::output()
{
for(int i=0;i<sizem;cout<<x[i]<<" ",i++);
cout<<"\n";
}
void DArray::output()
{ cout<<"\n";
for(int i=0;i<sizem;i++)
{ for(int j=0;j<sizen;j++)
cout<<z[i][j]<<" ";
cout<<"\n";
}
}
DArray::DArray()
{
int i;
sizen=sizem;
z=new int*[sizem]; // одно измерение уже есть, т.е. это одна строка
for(i=1;i<sizem;i++)
z[i]=new int[sizem];
for(int i=1;i<sizem;i++) // if i don't initialization matrix, all'll
works right,compiles,and run, but AFAIK when i allocate space dynamically,
it must be intitializationed self by zeros, but it isn't particually equal
zeroes, the fisrt two column are equal some random number, other
are equal zero.
for(int j=0;j<sizen;j++)
{
z[i][j]=2;
}
*z=x; // i've already array x , that was inheritanced, just point address
}
DArray::~DArray()
{
for(int i=1;i<sizem;i++)
delete z[i];
// yet one problem
// i can't delete x e.g. delete []x
// but it should work!
delete []z;
}
PS我的工作没有错误,但我认为有内存泄漏,但无法赶上原因
所有技巧都是在构造函数中完成的,其他一切都是输出矩阵/数组等常规内容。这就是为什么我认为那个问题存在的原因
thanks you mates!
但我还不明白一件事
z=new int*[sizem];
for(i=1;i<sizem;i++)
z[i]=new int[sizem];
for(int i=1;i<sizem;i++)
{
for(int j=0;j<sizen;j++)
cout<<z[i][j]<< " ";
cout<<"\n";
}
as i think i have to receive here ones zeros. byt i receive something like
2532336 2532336 0 0 0
2532336 2532336 0 0 0
2532336 2532336 0 0 0
2532336 2532336 0 0 0
为什么呢?
答案 0 :(得分:1)
z是一个二维数组......你已经为每个z [i]分配了一个内存作为数组。
所以你需要使用:
delete[] z[i];
答案 1 :(得分:1)
我从您的代码中提取了一个最小样本。
Array::Array()
{
sizem=5;
x = new int[sizem];
}
Array::~Array()
{
delete[] x;
}
DArray::DArray()
{
z = new int*[sizem];
for(int i=1; i < sizem; i++)
z[i]= new int[sizem];
*z=x; // Wierd but ok
}
DArray::~DArray()
{
for(int i=1;i<sizem;i++)
delete z[i]; // Should be delete[] since elements were allocated through z[i] = new int[sizem];
delete[] z;
}
答案 2 :(得分:1)
没有内存泄漏,但新增和删除之间存在一个不匹配:
您在这里使用new[]
:
for(i=1;i<sizem;i++)
z[i]=new int[sizem];
但您在这里使用delete
(不是delete[]
):
for(int i=1;i<sizem;i++)
delete z[i];
随着更改为delete[] z[i];
,valgrind没有警告:
==29235== HEAP SUMMARY:
==29235== in use at exit: 0 bytes in 0 blocks
==29235== total heap usage: 7 allocs, 7 frees, 160 bytes allocated
==29235==
==29235== All heap blocks were freed -- no leaks are possible
编辑:关于你的第二个问题,如果你想用零初始化数组,请使用
z[i] = new int[sizem](); // note the pair of parentheses
或者只是像其他人一样使用矢量。