valgrind工具的--memcheck选项用来对内存使用情况的检测。对动态申请的内存有效,所有malloc()/free()/new/delete的调用都会被捕获;通常用来排查如下问题:
1、使用未初始化的内存
2、野指针访问(读/写已经被释放的内存)
3、内存泄漏
4、读写内存越界
使用及分析方法如下:
示例代码如下:
// 文件名 test.c
编译:
gcc -g test.c -o test
执行内存检测:
valgrind --tool=memcheck --leak-check=yes ./test
执行结果解读:
==26499== ----- 26499为进程号,在多进程里面可区别进程
1、访问野指针
第10行无效写入,*pArr0 指针在第8行申请了内存,在第9行释放内存,第10行写入数据。
2、读写内存越界
第17行尝试给pArr[10] 赋值,但是数组的大小为10,从pArr[0]形如计,不存在pArr[10];写内存越界
3、使用未初始化的内存
由于第12行的初始化内存索引计算不正常,导致pArr[0]未被初始化;后面第15行使用该变量累加sum += pArr[i]时,也导致sum会被“infected”,当17行printf ("sum=%d\n", sum)时,由于被污染报错。必须要注意的是,pArr[0]变量未初始化发生成第12行,sum被污染发生在第15行,但是这两处都没有报错,而是在第17行使用sum的时候报错了。Valgrind没有给出主详细的线索,此时需要通过分析代码或者通过其它辅助方式来具体定位。
4、内存泄漏
这里比较清晰的给出是有40 bytes的内存没有正常释放,此时可以排查 一下前面的代码在如果申请了40 bytes大小的内存