码迷,mamicode.com
首页 > 其他好文 > 详细

Unix下C程序内存泄漏检测工具Valgrind安装与使用

时间:2017-07-14 11:10:56      阅读:149      评论:0      收藏:0      [点我收藏+]

标签:net   tar   html   content   csdn   memcpy   pre   编译   config   

Unix下C程序内存泄漏检测工具Valgrind安装与使用

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

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

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

 

官网

http://www.valgrind.org

 

下载与安装

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

 

测试代码

  1. #include
  2. int* func(void)
  3. {
  4.     int* x = malloc(10 * sizeof(int));
  5.     x[10] = 0; //问题1: 数组下标越界
  6. }
  7. int main(void)
  8. {
  9.     int* x=NULL;
  10.     x=func();
  11.     //free(x);
  12.     x=NULL;
  13.     return 0; //问题2: 内存没有释放
  14. }

编译

#gcc -g -o test test.c

 

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

 

报告:


技术分享

 

说明

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

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

 

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

技术分享

 

文档:

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

 

其他参考工具:likwid http://code.google.com/p/likwid/downloads/list

 

 ref: http://blog.sina.com.cn/s/blog_af9acfc601017vhs.html

Unix下C程序内存泄漏检测工具Valgrind安装与使用

标签:net   tar   html   content   csdn   memcpy   pre   编译   config   

原文地址:http://www.cnblogs.com/listenerln/p/7168916.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!