【问题标题】:c++ valgrind shows memory leak in hello world [duplicate]c ++ valgrind在hello world中显示内存泄漏[重复]
【发布时间】:2016-03-08 15:20:41
【问题描述】:

我的程序代码是

#include <iostream>

int main(int argc, const char *argv[])
{
  std::cout << "hello world!\n";
  return 0;
}

我用标志编译它

-Wpedantic -pedantic-errors -std=c++11 -g -Wall -Wextra

在上面运行Valgrind,看到一些奇怪的东西,这个简单的程序有内存泄漏,valgrind --leak-check=full --show-leak-kinds=all命令的输出是

==4492== 72,704 bytes in 1 blocks are still reachable in loss record 1 of 1
==4492==    at 0x4C28C20: malloc (vg_replace_malloc.c:296)
==4492==    by 0x4EBF11F: ??? (in /usr/lib/x86_64-linux-gnu/libstdc++.so.6.0.21)
==4492==    by 0x400E9F9: call_init.part.0 (dl-init.c:78)
==4492==    by 0x400EAE2: call_init (dl-init.c:36)
==4492==    by 0x400EAE2: _dl_init (dl-init.c:126)
==4492==    by 0x40011C9: ??? (in /lib/x86_64-linux-gnu/ld-2.19.so)

我的问题是 - 如何找出发生了什么?

【问题讨论】:

    标签: c++ memory-leaks standard-library


    【解决方案1】:

    这是 linux 系统动态库加载器永久保留的内存。找出发生了什么的方法包括阅读 _dl_init() 函数的代码,例如:here。另一种选择是使用调试器单步执行您的程序,您需要在运行前break _init,并且可能还使用disassemblesi,因为glibc 不能在未优化的情况下构建。

    查看讨论 here(可能标记为 dup)

    【讨论】:

      猜你喜欢
      • 2012-05-25
      • 1970-01-01
      • 2020-03-31
      • 2016-03-15
      • 1970-01-01
      • 1970-01-01
      • 2019-02-10
      • 1970-01-01
      • 1970-01-01
      相关资源
      最近更新 更多