前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Unix下c程序内存泄露检测工具

Unix下c程序内存泄露检测工具

作者头像
猿人谷
发布2018-01-17 11:15:03
1.4K0
发布2018-01-17 11:15:03
举报
文章被收录于专栏:猿人谷猿人谷

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

测试代码

[cpp] view plaincopy

代码语言:js
复制
#include <stdlib.h> 
int* func(void)  
{  
 int* x = malloc(10 * sizeof(int));  
   x[10] = 0;  //问题1: 数组下标越界 
}                    
 int main(void)  
{  
 int* x=NULL;  
   x=func();  
 //free(x);   
   x=NULL;  
 return 0;   //问题2: 内存没有释放 
 }  

编译

#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

  1. 其他参考工具:likwid  http://code.google.com/p/likwid/downloads/list
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2012-12-17 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档