意外的内存泄漏[Valgrind]

时间:2010-01-28 06:49:33

标签: c++ valgrind

今天我只是想检查一下valgrind是如何工作的。所以我创建了一个简单的程序。

//leak.C
#include<iostream>

class leak
{

   int *p;

   public:

   leak():p(new int[10]()){std::cout<<"Constructor of leak called\n";}
   virtual void set()
   {

       for(int i=0;i<10;++i) p[i]=i*i;
   }

   virtual void display()
   {
       std::cout<<"In leak's display()\n";
       for(int i=0;i<10;++i) std::cout<<p[i]<<std::endl;
   }

   virtual ~leak()
   {
       std::cout<<"Destructor of leak called\n";
       delete[] p;
   }
};

class exleak: public leak
{

     double *r;

     public:

     exleak():r(new double[5]()){std::cout<<"Constructor of exleak called\n";}

     void set()
     {
       leak::set();
       for(int i=0;i<5;i++) r[i]=i*3.0;
     }


     void display()
     {
         leak::display();
         std::cout<<"In exleak's display()\n";
         for(int i=0;i<5;i++)  std::cout<<r[i]<<std::endl;
     }

     ~exleak()
     {

          std::cout<<"Destructor of exleak called\n";
          delete[] r;
     }
};

int main()
{

     leak *x=new exleak();
     x->set();
     x->display();
     delete x;

}

输出符合预期。我预计没有内存泄漏。 我编译了文件leak.C并生成了可执行文件leak。 但当我输入以下命令valgrind --leak-check=yes --verbose ./leak时,我感到很惊讶。代码有内存泄漏。 :-o

这就是我得到的。

==9320== 
==9320== HEAP SUMMARY:
==9320==     in use at exit: 12 bytes in 1 blocks
==9320==   total heap usage: 3 allocs, 2 frees, 92 bytes allocated
==9320== 
==9320== 12 bytes in 1 blocks are definitely lost in loss record 1 of 1
==9320==    at 0x40263A0: operator new(unsigned int) (vg_replace_malloc.c:214)
==9320==    by 0x8048B0E: main (in /home/prasoon/leak)
==9320== 
==9320== LEAK SUMMARY:
==9320==    definitely lost: 12 bytes in 1 blocks
==9320==    indirectly lost: 0 bytes in 0 blocks
==9320==      possibly lost: 0 bytes in 0 blocks
==9320==    still reachable: 0 bytes in 0 blocks
==9320==         suppressed: 0 bytes in 0 blocks
==9320== 
==9320== For counts of detected and suppressed errors, rerun with: -v
==9320== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 25 from 6)

代码如何泄漏内存?

  definitely lost: 12 bytes in 1 blocks //WHERE?

编辑已解决的问题

3 个答案:

答案 0 :(得分:2)

我在2.6.18-164.11.1.el5内核和GCC 4.1.2的Linux上试过它,它没有给我任何泄漏

我认为代码没有任何问题

答案 1 :(得分:0)

gcc(Ubuntu 5.4.0-6ubuntu1〜16.04.10)5.4.0 20160609
valgrind-3.11.0

没有收到任何警告

enter image description here

答案 2 :(得分:-1)

class exleak没有虚拟析构函数......