Неожиданная утечка памяти [Valgrind] - PullRequest
3 голосов
/ 28 января 2010

Сегодня я просто пытался проверить, как работает 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, я был удивлен. В коде произошла утечка памяти. : -О

Это то, что я получил.

==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 ]

2 голосов
/ 28 января 2010

Я попробовал это на Linux с 2.6.18-164.11.1.el5 ядром и GCC 4.1.2, это не дает мне утечки

и я не вижу проблем с кодом

0 голосов
/ 09 декабря 2018

gcc (Ubuntu 5.4.0-6ubuntu1 ~ 16.04.10) 5.4.0 20160609
Valgrind-3.11.0

не получить предупреждение

enter image description here

0 голосов
/ 28 января 2010

У класса exleak нет виртуального деструктора ...

...