Пулы std :: string в C ++, отладочные сборки?проблемы std :: string и valgrind - PullRequest
11 голосов
/ 08 июня 2010

У меня проблема со многими предупреждениями valgrind о возможных утечках памяти в std :: string, например:

120 bytes in 4 blocks are possibly lost in loss record 4,192 of 4,687
    at 0x4A06819: operator new(unsigned long) (vg_replace_malloc.c:230)
    by 0x383B89B8B0: std::string::_Rep::_S_create(unsigned long, unsigned long, std::allocator<char> const&) (in /usr/lib64/libstdc++.so.6.0.8)
    by 0x383B89C3B4: (within /usr/lib64/libstdc++.so.6.0.8)
    by 0x383B89C4A9: std::basic_string<char, std::char_traits<char>, std::allocator<char> >::basic_string(char const*, unsigned long, std::allocator<char> const&) (in /usr/lib64/libstdc++.so.6.0.8)

Мне интересно:

  • использует ли std :: string (GCC 4.1.2) пулы памяти?
  • если да, есть ли способ отключить пулы (в виде отладочной сборки и т. Д.)?

Ответы [ 6 ]

6 голосов
/ 08 июня 2010

Проверьте FAQ .В контейнерах есть раздел о «Утечки памяти» .Вам следует

  • проверить вашу версию Valgrind
  • , использовать отладочную сборку вашей программы (и не оптимизированную)
  • и определить GLIBCXX_FORCE_NEW при необходимости.(Это переменная среды, которая влияет на поведение вашей программы во время выполнения, а не на время компиляции #define, как вы могли бы ожидать.)
3 голосов
/ 08 июня 2010

Это похоже на ложное срабатывание. Это может быть подавлено, как описано в руководстве

2 голосов
/ 08 июня 2010

Если я правильно помню, многие распределители STL реализуют какое-то удержание памяти. То есть они не освобождают выделенную память сразу, а сохраняют ее и используют повторно. У меня наверняка было много ложных срабатываний в valgrind из памяти, выделенной моей реализацией STL.

Лучший способ, который я нашел для решения этой проблемы, - это (просто) использовать файл подавления.

1 голос
/ 08 июня 2010

120 байтов недостаточно для пула. Выходите ли вы () из своей программы?

0 голосов
/ 27 ноября 2016

У меня была эта проблема, потому что моя программа прекратила работу из-за необработанного исключения.Очевидно, обработчик для необработанных исключений не очищает все.

0 голосов
/ 18 февраля 2015

У меня просто была эта проблема, и для меня это было потому, что я связывался с версией разработки для библиотеки, но мой тестовый код собирал более старую версию, установленную системой. Изменения были достаточно тонкими, чтобы связать их и запустить без каких-либо явных проблем, но Valgrind обнаружил странные утечки. Использование ldd вместо valgrind подтвердило, что он подобрал неверный файл библиотеки. Установка LD_LIBRARY_PATH корректно исправила его, хотя правильное решение - увеличить версию библиотеки, поскольку она, очевидно, больше не будет обратно совместимой, если это произойдет.

Я также видел эту проблему, когда объект не был уничтожен должным образом, например, класс с virtual функциями, в которых отсутствует деструктор virtual. Когда класс помещается в указатель на базовый класс, а затем уничтожается, запускается только деструктор базового класса, пропускающий все, что размещено в производных классах, например, std::string экземпляры в вашем примере. Подсказка заключалась в том, чтобы проверить, какой класс использовал утечку string, и следовать иерархии классов обратно к базовому классу и убедиться, что у нее есть явный деструктор virtual, даже пустой. Я предполагал, что они были неявными, если в классе есть virtual функции, но, очевидно, нет, и GCC не предупреждает вас об этом.

...