源码网商城,靠谱的源码在线交易网站 我的订单 购物车 帮助

源码网商城

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

  • 时间:2022-06-09 04:00 编辑: 来源: 阅读:
  • 扫一扫,手机访问
摘要:Unix下C程序内存泄漏检测工具Valgrind的安装与使用详解
Valgrind是一款用于内存调试、内存泄漏检测以及性能分析的软件开发工具。 Valgrind的最初作者是Julian Seward,他于2006年由于在开发Valgrind上的工作获得了第二届Google-O'Reilly开源代码奖。 Valgrind遵守GNU通用公共许可证条款,是一款自由软件。 [b]官网 [/b][url=http://www.valgrind.org/]http://www.valgrind.org [/url]  [b]下载与安装 [/b]#wget http://www.valgrind.org/downloads/[b][url=http://xiazai.jb51.net/201308/yuanma/valgrind-3.8.1(jb51.net).rar]valgrind-3.8.1.tar.bz2 [/url][/b]#tar xvf valgrind-3.8.1.tar.bz2 #cd valgrind-3.8.1 #./configure --prefix=/usr/local/webserver/valgrind #make #make install [b]测试代码 [/b]
[u]复制代码[/u] 代码如下:
#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: 内存没有释放  }
[b]编译 [/b]#gcc -g -o test test.c [b]内存检查 [/b]#valgrind --tool=memcheck --leak-check=yes --show-reachable=yes ./test [b]报告: [/b][img]http://files.jb51.net/file_images/article/201308/201308130856492.jpg[/img] [b]说明 [/b]Invalid write of size 4:表示数组越界写了4字节 40 bytes in 1 blocks:表示因程序退出而发生内存泄露40字节 修复bug,重新检查提示已经没有内存泄露 [img]http://files.jb51.net/file_images/article/201308/201308130856493.jpg[/img] [b]文档: [/b]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
  • 全部评论(0)
联系客服
客服电话:
400-000-3129
微信版

扫一扫进微信版
返回顶部