Unix/Linux下C程序内存泄露检测工具Valgrind的安装和使用

1 简单介绍

  Valgrind是一款用于内存调试、内存泄漏检测以及性能分析的软件开发工具。

  Valgrind的最初作者是Julian Seward,他于2006年由于在开发Valgrind上的工作获得了第二届Google-O'Reilly开源代码奖。

  Valgrind遵守GNU通用公共许可证条款,是一款自由软件。

  Websitehttp://www.valgrind.org


2 下载与安装

  #wgethttp://www.valgrind.org/downloads/valgrind-3.8.1.tar.bz2
  #tar -jxvf valgrind-3.8.1.tar.bz2
  #cd valgrind-3.8.1
  #./configure --prefix=/usr/local/webserver/valgrind
  #make
  #make install


3 使用方法

-> 编译

  #gcc -g -o test test.c

-> 内存检查
  #valgrind --tool=memcheck --leak-check=yes --show-reachable=yes ./test

报告:


Unix/Linux下C程序内存泄露检测工具Valgrind的安装和使用_第1张图片

说明:

  Invalid write of size 4:表示数组越界写了4字节

  40 bytes in 1 blocks:表示因程序退出而发生内存泄露40字节

  修复bug,重新检查提示已经没有内存泄露

Unix/Linux下C程序内存泄露检测工具Valgrind的安装和使用_第2张图片

Valgrind 中包含的 Memcheck 工具可以检查以下的程序错误:
  使用未初始化的内存 (Use of uninitialised memory)
  使用已经释放了的内存 (Reading/writing memory after it has been free’d)
  使用超过malloc分配的内存空间(Reading/writing off the end of malloc’d blocks)
  对堆栈的非法访问 (Reading/writing inappropriate areas on the stack)
  申请的空间是否有释放 (Memory leaks – where pointers to malloc’d blocks are lost forever)
  malloc/free/new/delete申请和释放内存的匹配(Mismatched use of malloc/new/new [] vs free/delete/delete [])
  src和dst的重叠(Overlapping src and dst pointers in memcpy() and related functions)
  重复free


4 其他参考

  如果想进一步了解使用命令,可以参考:http://blog.csdn.net/luxiuwen/article/details/7659128

你可能感兴趣的:(Unix/Linux下C程序内存泄露检测工具Valgrind的安装和使用)