c ++继承darray from array

时间:2011-06-04 14:48:33

标签: c++

我在教育目的这样做。  这样的想法:   我有类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 

为什么呢?

3 个答案:

答案 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

或者只是像其他人一样使用矢量。