Вы можете проверить, какие адреса выделяются, используя опцию --trace-malloc=yes
. Я бы посоветовал не использовать его в большом приложении!
Например, с этим небольшим приложением
int main()
{
int* pi = new int;
delete pi;
}
я получаю
paulf> ./vg-in-place --trace-malloc=yes ../vg_examples/noleak
==88971== Memcheck, a memory error detector
==88971== Copyright (C) 2002-2017, and GNU GPL'd, by Julian Seward et al.
==88971== Using Valgrind-3.16.0.GIT and LibVEX; rerun with -h for copyright info
==88971== Command: ../vg_examples/noleak
==88971==
--88971-- _Znwm(4) = 0x5800040
--88971-- _ZdlPv(0x5800040)
==88971==
==88971== HEAP SUMMARY:
==88971== in use at exit: 0 bytes in 0 blocks
==88971== total heap usage: 1 allocs, 1 frees, 4 bytes allocated
==88971==
==88971== All heap blocks were freed -- no leaks are possible
==88971==
==88971== For lists of detected and suppressed errors, rerun with: -s
==88971== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
Пара замечаний
- Возможно, вы захотите запустить
valgrind
вместо vg-in-place
, если только вы не создаете Valgrind самостоятельно. - Имена функций искажены. Если вы хотите увидеть не искаженные имена, вы можете запустить
paulf> ./vg-in-place --trace-malloc=yes ../vg_examples/noleak 2>&1 | /usr/bin/c++filt
[snip]
--89034-- operator new(unsigned long)(4) = 0x5800040
--89034-- operator delete(void*)(0x5800040)