Valgrind简记

原创 2013年12月05日 12:14:27

一. Valgrind是什么?

Valgrind是一个提供程序调试及性能分析的工具集。其包含的工具主要有Memcheck,Cachegrind,Callgrind,Massif等。其中,最为常用的是Memcheck,其主要用来检查程序heap上的内存使用情况。本文档主要介绍Memcheck的用法和一些使用技巧。

其官方网站是: http://valgrind.org/

Valgrind快速入门指南
英文:http://valgrind.org/docs/manual/QuickStart.html
中文:http://wenku.baidu.com/view/91fa21661ed9ad51f01df2c8.html

Valgrind用户手册
英文: http://valgrind.org/docs/manual/manual.html
中文: http://wenku.baidu.com/view/e7cec4eb19e8b8f67c1cb94c.html


二. Valgrind能干什么不能干什么?

Valgrind主要用来检查程序中可能出现的以下问题:
1. Use of uninitialised memory
2. Reading/writing memory after it has been free’d
3. Reading/writing off the end of malloc’d block
4. Memory leaks -- where pointers to malloc’d blocks are lost foreve
5. Mismatched use of malloc/new/new [] vs free/delete/delete []
6. Overlapping src and dst pointers in memcpy() and related functions


其功能约束如下:
1. 只能检查heap上的错误,不能检查出static和stack内存的使用,如数组越界等。
2. 不能指出为什么泄漏,也不能指出在哪内存泄漏
3. 指出的错误并非100%正确,但建议在编译时至少以warning的心态对待它们。


三. Valgrind的安装与部署



若有root权限,其安装方式如下:
1. 从官网上下载valgrind 安装包:http://valgrind.org/downloads/valgrind-3.3.0.tar.bz2
2. 用bzip2及tar命令解压压缩包。
3. 进入解压目录,运行./configure
4. 运行“make”命令
5. 运行“make install”命令
6. 将valgrind/bin加到$PATH路径中7. 运行“valgrind ls -l”测试valgrind是否已经正确安装到计算机上。若正确安装,则会出现类似第四部分的报错信息。


若没有root权限,则在第3步时,可以用--prefix指定安装的目录
./configure --prefix=/home/work/tools/ --exec-prefix=/home/work/tools/
以下步骤相同。


四. Valgrind使用示例及报错信息说明



编写程序test.cpp如下:


      1 #include <iostream>
      2 using namespace std;
      3 
      4 int main()
      5 {
      6     int *a = new int[10];
      7     a[11] = 0;
      8     cout << a[11]<< endl;
      9     return 0;
     10 }
     11


编译该程序:gcc –g –o test test.cpp
注意加入-g参数,便于valgrind读入符号表之类的信息以提供更丰富的错误定位信息。不推荐加入-O等优化参数,因为优化后的代码易于让valgrind解释错误。


运行“valgrind --tool=memcheck --leak-check=yes --show-reachable=yes test”,显示如下信息:
 
==2051== Memcheck, a memory error detector.
==2051== Copyright (C) 2002-2007, and GNU GPL'd, by Julian Seward et al.
==2051== Using LibVEX rev 1804, a library for dynamic binary translation.
==2051== Copyright (C) 2004-2007, and GNU GPL'd, by OpenWorks LLP.
==2051== Using valgrind-3.3.0, a dynamic binary instrumentation framework.
==2051== Copyright (C) 2000-2007, and GNU GPL'd, by Julian Seward et al.
==2051== For more details, rerun with: -v
==2051== 
==2051== Invalid write of size 4
==2051==    at 0x4009C6: main (test.cpp:7)
==2051==  Address 0x4a2005c is 4 bytes after a block of size 40 alloc'd
==2051==    at 0x490581B: operator new[](unsigned long) (vg_replace_malloc.c:274)
==2051==    by 0x4009B9: main (test.cpp:6)
==2051== 
==2051== Invalid read of size 4
==2051==    at 0x4009D4: main (test.cpp:8)
==2051==  Address 0x4a2005c is 4 bytes after a block of size 40 alloc'd
==2051==    at 0x490581B: operator new[](unsigned long) (vg_replace_malloc.c:274)
==2051==    by 0x4009B9: main (test.cpp:6)
0
==2051== 
==2051== ERROR SUMMARY: 2 errors from 2 contexts (suppressed: 9 from 4)
==2051== malloc/free: in use at exit: 40 bytes in 1 blocks.
==2051== malloc/free: 1 allocs, 0 frees, 40 bytes allocated.
==2051== For counts of detected errors, rerun with: -v
==2051== searching for pointers to 1 not-freed blocks.
==2051== checked 198,560 bytes.
==2051== 
==2051== 
==2051== 40 bytes in 1 blocks are definitely lost in loss record 1 of 1
==2051==    at 0x490581B: operator new[](unsigned long) (vg_replace_malloc.c:274)
==2051==    by 0x4009B9: main (test.cpp:6)
==2051== 
==2051== LEAK SUMMARY:
==2051==    definitely lost: 40 bytes in 1 blocks.
==2051==      possibly lost: 0 bytes in 0 blocks.
==2051==    still reachable: 0 bytes in 0 blocks.
==2051==         suppressed: 0 bytes in 0 blocks.




其中:
1. ==2014== 表示进程号信息,基本没用。
2. 接下来是Memcheck的版权声明信息。
3. 详细的报错信息,如at 0x4009C6: main (test.cpp:7) Address 0x4a2005c is 4 bytes after a block of size 40 alloc'd
说明test.cpp的第7行发生内存访问越界,越界的位移为4。
4. ERROR SUMMARY下面为错误汇总信息。
5. 接着是内存泄漏信息。说明有40byte的内存泄漏。
6. LEAK SUMMARY为内存泄漏信息。
在LEAK SUMMARY中:
definitely lost:表明没有任何指针指向该区域,已经造成了内存泄漏。
possibly lost:存在指针指向内存中的某个位置,valgrind认为你有可能是在做一些其他的高级应用(将指针放在申请的内存块中间)
still reachable:仍有指针引用该内存块,只是没有释放而已,可以通过设置—show-reachable=yes来报错。


五. Valgrind常用命令参数

1. --tool=<name> [default=memcheck]
--tool参数指明所要使用valgrind的哪一个工具,默认的为memcheck。因为大多数情况下我们只会用到memcheck工具,因此该参数可以不写。


2. --leak-check=<no|summary|yes|full>[default:summary]
在退出时检查是否有泄漏。Summary只是告诉我们有多少次泄漏,yes或full会告诉我们每次泄漏的详细信息。


3. --show-reachable=<yes|no>[default:no]
通过设定该参数为yes,则显示still reachable类型的内存泄漏信息。


其他更多的运行参数信息可以查看《valgrind使用指南》及《valgrind manual》。
版权声明:本文为博主原创文章,未经博主允许不得转载。

相关文章推荐

练习简记第一期

  • 2007年06月08日 15:39
  • 36KB
  • 下载

英语音标简记法-英语学习

  • 2008年12月15日 15:45
  • 390KB
  • 下载

【简记】Operating System—— memory management(分页,分段,页表大小计算)

This memo is based on the course of Dr.Li with Operating System as the reference book.本章内容: 页式内存管理(非...

QCom MSM MDP显示驱动一些点的简记

简要记录了Qualcom MSM8xxx MDP Framebuffer驱动中的一些点。 Framebuffer设备的sysfs 330static int msm_fb_create_sysfs...

JVM中的垃圾收集算法和Heap分区简记

如何判断垃圾对象? 垃圾收集的第一步就是先需要算法来标记哪些是垃圾,然后再对垃圾进行处理。   引用计数(ReferenceCounting)算法 这种方法比较简单直观,Fla...

ArcGIS Server for linux 服务无法启动解决简记

今天在一台Linux虚拟机上安装了一个ArcGIS Server For Linux(只ArcSOC)组件,一切正常,但是启动服务的时候报一下的错误: [root@rhsde scripts]# ....

期货大作手风云录 --简记

期货大作手风云录 –简记周末一口气把期货大作手看完了,根本停不下来。有很多让人拍案叫绝的交易思路和方法,以及各种毁三观的交易现实。建仓印象比较深的是建仓方法。人总是会犯错误的,不可能总是看多就涨,看空...

Mysql一主多从和读写分离配置简记

近期开发的系统中使用MySQL作为数据库,由于数据涉及到Money,所以不得不慎重。同时,用户对最大访问量也提出了要求。为了避免Mysql成为性能瓶颈并具备很好的容错能力,特此实现主从热备和读写分离。...

Android 些许问题简记

Failure [INSTALL_PARSE_FAILED_NO_CERTIFICATES]

【简记】Java Web 内幕——一次完整的HTTP事务是怎样一个过程?

B/S 网络架构: http://blog.csdn.net/m13666368773/article/details/8060481 (简单地解释了正向代理和反向代理,很清晰!)(转)一次完整的H...
内容举报
返回顶部
收藏助手
不良信息举报
您举报文章:Valgrind简记
举报原因:
原因补充:

(最多只允许输入30个字)