可以valgrind报告丢失块的内存地址(用于调试递归函数调用)

Can valgrind report a memory address of a lost block (for debugging recursive function calls)?

本文关键字:用于 调试 递归 函数调用 地址 内存 报告 valgrind 可以      更新时间:2023-10-16

这个问题与我的问题最相似,但它相当古老,所以我想知道从那以后是否有什么变化。

我的valgrind输出是:

==29443== 109 (16 direct, 93 indirect) bytes in 2 blocks are definitely lost in loss record 270 of 309
==29443==    at 0x4C2B0E0: operator new(unsigned long) (in /usr/lib/valgrind/vgpreload_memcheck-amd64-linux.so)
==29443==    by 0x4F4E8DB: grl::Configuration::Configuration(grl::Configuration const&) (configuration.h:192)
==29443==    by 0x4F49973: grl::YAMLConfigurator::load(YAML::Node const&, grl::Configuration*, std::string const&) (configurable.cpp:74)
==29443==    by 0x4F499FC: grl::YAMLConfigurator::load(YAML::Node const&, grl::Configuration*, std::string const&) (configurable.cpp:75)
==29443==    by 0x4F499FC: grl::YAMLConfigurator::load(YAML::Node const&, grl::Configuration*, std::string const&) (configurable.cpp:75)
==29443==    by 0x4F499FC: grl::YAMLConfigurator::load(YAML::Node const&, grl::Configuration*, std::string const&) (configurable.cpp:75)
==29443==    by 0x40C78E: grl::YAMLConfigurator::load(std::string, grl::Configuration*, std::string const&) (configurable.h:321)
==29443==    by 0x40B897: main (deployer.cpp:180)

程序在开始时配置为递归调用从yaml文件读取并将所有所需参数存储在映射中作为一对(name, allocated address)。我可以打印这些双。因此,如果valgrind可以告诉我一个丢失值的地址,那么我就可以获得一个参数的名称,并检查它为什么没有被释放。

如果功能不可用,我还能用什么?

您可以使用vgdb在valgrind+gdb下运行程序。看见http://www.valgrind.org/docs/manual/manual-core-adv.html#manual-core-adv.gdbserver

然后,您可以使用各种valgrind memcheck monitor命令来执行泄漏搜索并具有泄漏块的地址/大小。看见http://www.valgrind.org/docs/manual/mc-manual.html#mc-manual.monitor-命令