valgrind神器之--memcheck内存使用情况检测

       valgrind工具的--memcheck选项用来对内存使用情况的检测。对动态申请的内存有效,所有malloc()/free()/new/delete的调用都会被捕获;通常用来排查如下问题:
1、使用未初始化的内存
2、野指针访问(读/写已经被释放的内存)
3、内存泄漏
4、读写内存越界

使用及分析方法如下:

示例代码如下:

 //  文件名 test.c

valgrind神器之--memcheck内存使用情况检测

 

编译:

 gcc -g test.c -o test

执行内存检测:

valgrind --tool=memcheck --leak-check=yes ./test

执行结果解读:

==26499==         ----- 26499为进程号,在多进程里面可区别进程

1、访问野指针 

valgrind神器之--memcheck内存使用情况检测

第10行无效写入,*pArr0 指针在第8行申请了内存,在第9行释放内存,第10行写入数据。

2、读写内存越界

valgrind神器之--memcheck内存使用情况检测

第17行尝试给pArr[10] 赋值,但是数组的大小为10,从pArr[0]形如计,不存在pArr[10];写内存越界

3、使用未初始化的内存

valgrind神器之--memcheck内存使用情况检测

 由于第12行的初始化内存索引计算不正常,导致pArr[0]未被初始化;后面第15行使用该变量累加sum += pArr[i]时,也导致sum会被“infected”,当17行printf ("sum=%d\n", sum)时,由于被污染报错。必须要注意的是,pArr[0]变量未初始化发生成第12行,sum被污染发生在第15行,但是这两处都没有报错,而是在第17行使用sum的时候报错了。Valgrind没有给出主详细的线索,此时需要通过分析代码或者通过其它辅助方式来具体定位。

 4、内存泄漏

valgrind神器之--memcheck内存使用情况检测

 这里比较清晰的给出是有40 bytes的内存没有正常释放,此时可以排查 一下前面的代码在如果申请了40 bytes大小的内存

 

上一篇:valgrind ----直接使用参数


下一篇:valgrind