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。