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大小的内存
本文详细讲解了Valgrind工具的memcheck选项在内存使用检查中的应用,包括检测未初始化内存、野指针、越界访问和内存泄漏,通过实例代码演示并解析执行结果。
3627

被折叠的 条评论
为什么被折叠?



