Valgrind工具使用

Valgrind附带了一组工具,例如著名的memcheck工具。它执行某种调试、代码分析或类似的任务,帮助您改进程序。Valgrind体系结构是模块化的,因此可以轻松地创建新工具,而不影响现有结构。

一系列有名的工具如下所示:

1.Memcheck是一个内存错误探测器,它帮助你的C C++程序更加正确,性能更加出色;

2.Cachegrind是高速缓存和分支预测分析器。它帮助你使程序运行得更快;

3.Callgrind是一个叫图生成缓存分析器。它和Cachegrind功能有一些重叠,也收集了一些Cachegrind不能收集到的信息。

4.Helgrind是一个线程错误检测器。它帮助您使多线程程序更正确。

5.DRD Helgrind类似也是线程错误检测器,但是DRD用的是不同的分析技术,因此可能发现不同的问题。

6.Massif是一个堆分析器,它能够帮助你用更少的内存。

7.DHAT是一种不同类型的堆分析器。 它可以帮助您了解块寿命,块利用率和布局低效问题。

8.SGcheck是一个可以检测堆栈和全局数组溢出的实验工具。 它的功能与Memcheck的功能是互补的:SGcheck发现了Memcheck无法解决的问题,反之亦然。

9.BBV是一个实验性的SimPoint基本块矢量生成器。 计算机体系结构的人常用它来做研究和开发。

下面看一个小例子,参照valgrind手册的例子程序。

#include <stdio.h>
#include <string.h>

void func( void )
{
   int *x  = malloc( 10 * sizeof(int ) );
   x[10] = 0;
}
int main( int argc, char **argv )
{
   func();
   return 0;
}

gcc编译生成可执行文件,在终端上输入:


程序运行结束之后,看到valgrind的输出信息:


以上报告两处错误,Invalid write of size 4,是因为我们给数组的第10个元素赋值0,发生访问越界,在run.c文件的第7行发生这样的错误。

然后我们只malloc没有free,valgrind提示我们在run.c第6行发生。

leak-check=full选项是输出详细信息,问题代码的所在的行,这样会显得更清晰,show-reachable用来控制是否显示控制之外的泄漏,如果设置为no,那么全局指针static指针将无法检测到。

作者在实际开发中,valgrind主要用来分析代码的内存泄漏问题,其它的工具还没用过。

valgrind有官网,上面有详细的说明文档,如有更深层次的需要,可移步官网Valgrind


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值