Valgrind是执行在Linux上一套基于仿真技术的程序调试和分析工具,它包括一个内核──一个软件合成的CPU,和一系列的小工具,每一个工具都能够完毕一项任务──调试。分析,或測试等。

Valgrind能够检測内存泄漏和内存违例,还能够分析cache的使用等,灵活轻巧而又强大,能直穿程序错误的心脏。真可谓是程序猿的瑞士军刀。

一、Valgrind的主要功能

  Valgrind工具包包括多个工具,如Memcheck,Cachegrind,Helgrind,Callgrind,Massif。以下分别介绍个工具的作用:

Memcheck 工具主要检查以下的程序错误:

  1.使用未初始化的内存 (Use of uninitialised memory)

  2.使用已经释放了的内存 (Reading/writingmemory after it has been free’d)

  3.使用超过 malloc分配的内存空间(Reading/writing off the end of malloc’d blocks)

  4.对堆栈的非法訪问 (Reading/writinginappropriate areas on the stack)

  5.申请的空间是否有释放 (Memory leaks –where pointers to malloc’d blocks are lost forever)

  6.malloc/free/new/delete申请和释放内存的匹配(Mismatched use of malloc/new/new [] vs free/delete/delete [])

  7.src和dst的重叠(Overlapping src and dst pointers in memcpy() and related functions)

Callgrind

  Callgrind收集程序执行时的一些数据。函数调用关系等信息,还能够有选择地进行cache模拟。在执行结束时。它会把分析数据写入一个文件。

callgrind_annotate能够把这个文件的内容转化成可读的形式。

Cachegrind

        它模拟 CPU中的一级缓存I1,D1和L2二级缓存,可以精确地指出程序中 cache的丢失和命中。假设须要。它还可以为我们提供cache丢失次数。内存引用次数,以及每行代码。每一个函数,每一个模块。整个程序产生的指令数。

这对优化程序有非常大的帮助。

Helgrind

  它主要用来检查多线程程序中出现的竞争问题。

Helgrind 寻找内存中被多个线程訪问,而又没有一贯加锁的区域,这些区域往往是线程之间失去同步的地方,并且会导致难以发掘的错误。

Helgrind实现了名为” Eraser” 的竞争检測算法,并做了进一步改进。降低了报告错误的次数。

Massif

  堆栈分析器。它能測量程序在堆栈中使用了多少内存,告诉我们堆块。堆管理块和栈的大小。

Massif能帮助我们降低内存的使用。在带有虚拟内存的现代系统中。它还可以加速我们程序的执行,降低程序停留在交换区中的几率

二. 使用Valgrind

Valgrind的使用很easy。valgrind命令的格式例如以下:

valgrind [valgrind-options]your-prog [your-prog options]

一些经常使用的选项例如以下:

-h --help

显示帮助信息。

--version

显示valgrind内核的版本号。每一个工具都有各自的版本号。

-q --quiet

安静地执行,仅仅打印错误信息。

-v --verbose

打印更具体的信息。

--tool= [default: memcheck]

最经常使用的选项。执行valgrind中名为toolname的工具。假设省略工具名,默认执行memcheck。

--db-attach= [default: no]

绑定到调试器上,便于调试错误。

我们通过样例看一下它的详细使用。

我们构造一个存在内存泄漏的C程序,例如以下:

#include
<stdio.h>

#include
<stdlib.h>

int*Test(void)

{

int*
x = malloc(10 *
sizeof(int));

delete
x;// problem 1: heap block overrun, problem 2: memory leak --x not free, only first address

return
x;

}

int main(void)

{

int
count;

Test();

printf("i =%d/n",
count); //problem 3: use uninitialised value.

return 0;

}

$ gcc -Wall -o Test Test.c

$ valgrind --tool=memcheck ./ Test

$valgrind --tool=memcheck --leak-check=yes ./Test

三、安装

$:sudo apt-get install valgrind

Valgrind的用法的更多相关文章

  1. [转]Valgrind简单用法

    [转]Valgrind简单用法 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian S ...

  2. Valgrind简单用法

    Valgrind的主要作者Julian Seward刚获得了今年的Google-O'Reilly开源大奖之一──Best Tool Maker.让我们一起来看一下他的作品.Valgrind是运行在Li ...

  3. Valgrind简单用法 (转)

    转自 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html Valgrind的主要作者Julian Seward刚获得了今年的G ...

  4. Valgrind 简单用法

    有时需要给自己写的小程序做个简单的 benchmark,查看内存使用情况和运行时间.这时可以试试 valgrind. Ubuntu 下安装很简单: sudo apt-get update sudo a ...

  5. 内存使用分析工具Valgrind简单用法

    转载自 http://www.cnblogs.com/sunyubo/archive/2010/05/05/2282170.html 暂时还未使用过,记录下,记录下,记录下 Valgrind的主要作者 ...

  6. 一个内存增长问题的分析和处理(二)——valgrind工具的用法

    valgrind是linux下对C++和C程序进行内存泄露检测的工具,除了内存检测,valgrind还提供了很多其他的功能,这里主要介绍下valgrind的内存检测的功能. 首先是文件的下载,valg ...

  7. valgrind检查C++内存泄漏

    valgrind --tool=memcheck --leak-check=full ./httptest Valgrind 使用 用法: valgrind [options] prog-and-ar ...

  8. valgrind 内存检测与调用图生成

    http://blog.csdn.net/destina/article/details/6198443  感谢作者的分享! 一  valgrind是什么? Valgrind是一套Linux下,开放源 ...

  9. 各个函数消耗的时间profiling和内存泄漏valgrind

    来源:http://06110120wxc.blog.163.com/blog/static/37788161201333112445844/ ARM(hisi)上面的profiling和valgri ...

随机推荐

  1. 六台机器搭建RedisCluster分布式集群

    原文:六台机器搭建RedisCluster分布式集群 版权声明:m_nanle_xiaobudiu https://blog.csdn.net/m_nanle_xiaobudiu/article/de ...

  2. 【Codeforces Round #460 (Div. 2) B】 Perfect Number

    [链接] 我是链接,点我呀:) [题意] 在这里输入题意 [题解] 直接暴力求出第k个perfect数字就好. 纯模拟. [代码] #include <bits/stdc++.h> #de ...

  3. 【Uva 1629】 Cake slicing

    [Link]: [Description] 给你一个n*m的格子; 然后里面零零散散地放着葡萄 让你把它切成若干个小矩形方格 使得每个小矩形方格都恰好包含有一个葡萄. 要求切的长度最短; 问最短的切割 ...

  4. HDU——T 1166 敌兵布阵

    http://acm.hdu.edu.cn/showproblem.php?pid=1166 Time Limit: 2000/1000 MS (Java/Others)    Memory Limi ...

  5. bzoj1084【SCOI2005】最大子矩阵

    1084: [SCOI2005]最大子矩阵 Time Limit: 10 Sec  Memory Limit: 162 MB Submit: 1946  Solved: 970 [Submit][id ...

  6. 基于r-Kernel的LiteOS操作系统

    LiteOS是应用于资源受限的传感网络的一种基于线程的类UNIX操作系统.也就是说它跑在存储空间和RAM有限的超低电压微控制器上,这也是吸引我关注它的原因(在超低电压下系统更易出错).它採用r-ker ...

  7. Android Studio升级到0.8.1后怎样设置字体大小?

    升级到0.8.1后.打开设置字体大小页面.你会发现无论是Default还是Darcula,都不同意你改变字体的大小.事实上这个是由于这两个模式是Android Studio自带模式,所以不同意你修改, ...

  8. jQuery源码04 data() : 数据缓存

    /* Implementation Summary 1. Enforce API surface and semantic compatibility with 1.9.x branch 2. Imp ...

  9. grunt yoman bower的理解

    grunt : 前端构建工具 1 什么事前端构建工具 目前前端已经开始了工程化 比如 一个项目 里面用到了几十个js文件 几十个css 很多图片资源 我们如果引入 还是按照以前的方式 out 因此这个 ...

  10. 小的时候.by小雷

    小的时候,总是有很多想法.   想去做,却做不成.   因为,自己小,被父母约束着,被学校圈着,被老师教育着. 想买个小霸王游戏机,没钱.在父辈的眼中,"游戏" ,游戏室,电脑游戏 ...