我需要知道如何找出共享库中的内存泄漏,这些内存泄漏将被加载到发布二进制文件中。我的意思是我用-g选项构建的共享库,但加载共享库的二进制文件不是用-g选项构建的。valgrind - 在共享库中查找内存泄漏
我得到泄漏报告如下。
==739== at 0x4A05809: malloc (vg_replace_malloc.c:149)
==739== by 0x84781B1: ???
==739== by 0x87507F5: ???
==739== by 0x874CF47: ???
==739== by 0x874E657: ???
==739== by 0x874F7C2: ???
==739== by 0x8779C0C: ???
请让我知道如何从共享库中获取泄漏的堆栈跟踪?
有一个补丁提供了一个选项来禁用卸载dlclose后的符号。该补丁的工作原理和我已经使用过很多次。但补丁是旧版本,我想现在它已经烂了。 https://bugs.kde.org/show_bug.cgi?id=79362 – k0n3ru
@TomH:让我指出,“omit dlclose”解决方法可能会导致大量误报。如果堆栈中存在销毁堆中元素的对象,那么这些元素会在输出中显示为泄漏,因为dlclose会首先完成销毁。 – newhouse
而第二个不工作,如果valgrind是64位,但你调试32 – newhouse