valgrind在C语言编程中,对程序的性能调试,判断一个程序的代码质量是否高效有很明显的用处。下面具体分析一下:

测试程序的CPU命中率(CPU cache hit/miss rate)
模拟写两个小程序,用来测试CPU的缓存命中率,分别名为cache1.c和cache2.c.

cache1.c代码如下:

#include 
                                                             
                                                             
 #define MAXROW 8000
 #define MAXCOL 8000
                                                             
 int main () {
                                                             
 int i,j;
 static int x[MAXROW][MAXCOL];
                                                             
 printf ("Starting!\n");
                                                             
          for (i=0;i 
  

cache2.c代码如下:

#include 
                                                        
 #define MAXROW 8000
 #define MAXCOL 8000
 int main () {
 int i,j;
 static int x[MAXROW][MAXCOL];
 printf ("Starting!\n");
          for (j=0;j 
  

编译cache1.c运行程序后查看命CPU缓存命中率结果
valgrind调试CPU缓存命中率和内存泄漏_第1张图片

编译cache2.c运行程序后查看命CPU缓存命中率结果

valgrind调试CPU缓存命中率和内存泄漏_第2张图片

显然是cache1的cache miss rate较低,程序的代码质量更高效.

补充:测试程序的内存泄漏(memory leak)

当前系统gcc的版本

wKiom1NLcSXToBIXAACvHEptLtE762.jpg

写个小的测试程序

#include 
                       
                       
 #define M 5
 int main(void) {
 int i;
 int a[M]={11,22,33,44,55};
 for (i=0;i 
  

使用默认功能的gcc编译,运行显示正常,其实已经存在数组越界的问题,那么再用valgrind测试一下程序的是否存在内存泄.

valgrind调试CPU缓存命中率和内存泄漏_第3张图片

结果也没有发现内存泄漏.

然后让gcc支持mudflap功能,RHEL/CentOS需要安装libmudflap-4.1.2-52.el5和libmudflap-devel-4.1.2-52.el5两个rpm包,再用gcc带mudflap功能编译,执行程序看效果

valgrind调试CPU缓存命中率和内存泄漏_第4张图片

可以看出当去读取数组下标为5的值时,出现了数组越界的问题,默认的gcc编辑器是不会去关心数组越界问题的.

以上是用valgrind测试内存泄漏的用法,不过有时valgrind检测不到,可以用mudflap的强大功能查出内存泄漏的问题,不过需要注意的是mudflap对系统资源的消耗也很大,有利有弊,在特定的时候用一下还是很不错的选择.