valgrind使用方法

2024-09-04 22:48
文章标签 使用 方法 valgrind

本文主要是介绍valgrind使用方法,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!


1. 概述

valgrind是一款的用于C/C++内存检测、性能优化的开源软件,而且非常轻量级,上手也非常快。一些大型企业也将valgrind对代码的检查纳入到CI构建系统中,实时保证代码质量。


这里就陆续对valgrind的一些功能进行介绍。//由于时间关系,一时无法全部分析清楚,因此本文会持续更新。


valgrind网站:http://www.valgrind.org/http://www.valgrind.org/


2. 软件安装

先从网站上下载一个版本,比如最新版本:

http://www.valgrind.org/downloads/current.html


下载完源码之后,首先解压缩:

tar -jxvf valgrind-3.9.0.tar.bz2    

然后可以看到README文件,这个文件中给出了安装的过程。如同大多数Linux上源码安装一样,3个步骤:

  • ./configure
  • make
  • makeinstall (如果用户权限不够,可以先切换到root)

检查安装结果:

root@myhost /home/test/valgrind/valgrind-3.9.0 # valgrind --version
valgrind-3.9.0
root@myhost # valgrind ls -l
==11706== Memcheck, a memory error detector
==11706== Copyright (C) 2002-2013, and GNU GPL'd, by Julian Seward et al.
==11706== Using Valgrind-3.9.0 and LibVEX; rerun with -h for copyright info
==11706== Command: ls -l
==11706== 
总用量 1832
-rw-r--r--  1 test users  38742 11月  1 07:33 aclocal.m4
-rw-r--r--  1 test users   3267 10月 28 18:30 AUTHORS
......................
-rwxr-xr-x  1 test users    691 10月 23 18:49 vg-in-place
-rw-r--r--  1 test users   2946 10月 23 18:50 xfree-3.supp
-rw-r--r--  1 test users   9018 10月 23 18:49 xfree-4.supp
==11706== 
==11706== HEAP SUMMARY:
==11706==     in use at exit: 14,997 bytes in 90 blocks
==11706==   total heap usage: 2,718 allocs, 2,628 frees, 167,722 bytes allocated
==11706== 
==11706== LEAK SUMMARY:
==11706==    definitely lost: 0 bytes in 0 blocks
==11706==    indirectly lost: 0 bytes in 0 blocks
==11706==      possibly lost: 0 bytes in 0 blocks
==11706==    still reachable: 14,997 bytes in 90 blocks
==11706==         suppressed: 0 bytes in 0 blocks
==11706== Rerun with --leak-check=full to see details of leaked memory
==11706== 
==11706== For counts of detected and suppressed errors, rerun with: -v
==11706== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
root@myhost /home/test/valgrind/valgrind-3.9.0 #               



3. 使用方法

3.1 参考资料

可以从网上下载使用文档,如pdf文档:http://www.valgrind.org/docs/manual/valgrind_manual.pdf


最好的学习方法就是实践。


3.2 一个简单的例子

要对代码使用valgrind,那么代码编译的时候需要添加调试选项。下面是一个简单的例子,可以对valgrind有个初步的了解。

代码:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>int main() {const size_t BUFFER_SIZE = 1024;char* buffer = (char*)malloc(sizeof(char) * BUFFER_SIZE);if (NULL == buffer) {printf("No more memory to allocate.\n");exit(1);}strcpy(buffer, "Hello, valgrind.");printf("%s\n", buffer);free(buffer);return 0;
}

编译、运行:

test@myhost ...me/test/examples/Cpp/valgrind/memcheck % gcc -g -o test main.c
test@myhost ...me/test/examples/Cpp/valgrind/memcheck % ./test
Hello, valgrind.
test@myhost ...me/test/examples/Cpp/valgrind/memcheck % valgrind --tool=memcheck ./test
==11946== Memcheck, a memory error detector
==11946== Copyright (C) 2002-2013, and GNU GPL'd, by Julian Seward et al.
==11946== Using Valgrind-3.9.0 and LibVEX; rerun with -h for copyright info
==11946== Command: ./test
==11946== 
Hello, valgrind.
==11946== 
==11946== HEAP SUMMARY:
==11946==     in use at exit: 0 bytes in 0 blocks
==11946==   total heap usage: 1 allocs, 1 frees, 1,024 bytes allocated
==11946== 
==11946== All heap blocks were freed -- no leaks are possible
==11946== 
==11946== For counts of detected and suppressed errors, rerun with: -v
==11946== ERROR SUMMARY: 0 errors from 0 contexts (suppressed: 0 from 0)
test@myhost ...me/test/examples/Cpp/valgrind/memcheck %        

目前为止,代码没有显示出任何问题。接下来在代码中增加一行:

++buffer;

即:

#include <stdio.h>
#include <stdlib.h>
#include <string.h>int main() {const size_t BUFFER_SIZE = 1024;char* buffer = (char*)malloc(sizeof(char) * BUFFER_SIZE);if (NULL == buffer) {printf("No more memory to allocate.\n");exit(1);}strcpy(buffer, "Hello, valgrind.");printf("%s\n", buffer);++buffer;free(buffer);return 0;
}

再次编译、运行:

test@myhost ...me/test/examples/Cpp/valgrind/memcheck % gcc -g -o test main.c
test@myhost ...me/test/examples/Cpp/valgrind/memcheck % ./test
Hello, valgrind.
[1]    11988 segmentation fault (core dumped)  ./test
139 test@myhost ...me/test/examples/Cpp/valgrind/memcheck % valgrind --tool=memcheck ./test
==12005== Memcheck, a memory error detector
==12005== Copyright (C) 2002-2013, and GNU GPL'd, by Julian Seward et al.
==12005== Using Valgrind-3.9.0 and LibVEX; rerun with -h for copyright info
==12005== Command: ./test
==12005== 
Hello, valgrind.
==12005== Invalid free() / delete / delete[] / realloc()
==12005==    at 0x4028F29: free (vg_replace_malloc.c:468)
==12005==    by 0x804850B: main (main.c:18)
==12005==  Address 0x4202029 is 1 bytes inside a block of size 1,024 alloc'd
==12005==    at 0x4029FB0: malloc (vg_replace_malloc.c:291)
==12005==    by 0x80484A8: main (main.c:7)
==12005== 
==12005== 
==12005== HEAP SUMMARY:
==12005==     in use at exit: 1,024 bytes in 1 blocks
==12005==   total heap usage: 1 allocs, 1 frees, 1,024 bytes allocated
==12005== 
==12005== LEAK SUMMARY:
==12005==    definitely lost: 1,024 bytes in 1 blocks
==12005==    indirectly lost: 0 bytes in 0 blocks
==12005==      possibly lost: 0 bytes in 0 blocks
==12005==    still reachable: 0 bytes in 0 blocks
==12005==         suppressed: 0 bytes in 0 blocks
==12005== Rerun with --leak-check=full to see details of leaked memory
==12005== 
==12005== For counts of detected and suppressed errors, rerun with: -v
==12005== ERROR SUMMARY: 1 errors from 1 contexts (suppressed: 0 from 0)
test@myhost ...me/test/examples/Cpp/valgrind/memcheck %      

此外,可以对照“ C代码的coredump”一文进行分析:

test@myhost ...me/test/examples/Cpp/valgrind/memcheck % ll
总用量 88
-rw------- 1 test users 335872  3月  3 20:52 core
-rw-r--r-- 1 test users    449  3月  3 20:52 main.c
-rw-r--r-- 1 test users    342  3月  3 20:41 main.c~
-rwxr-xr-x 1 test users   8004  3月  3 20:52 test*
test@myhost ...me/test/examples/Cpp/valgrind/memcheck % gdb ./test core
GNU gdb (GDB) 7.7
Copyright (C) 2014 Free Software Foundation, Inc.
License GPLv3+: GNU GPL version 3 or later <http://gnu.org/licenses/gpl.html>
This is free software: you are free to change and redistribute it.
There is NO WARRANTY, to the extent permitted by law.  Type "show copying"
and "show warranty" for details.
This GDB was configured as "i686-pc-linux-gnu".
Type "show configuration" for configuration details.
For bug reporting instructions, please see:
<http://www.gnu.org/software/gdb/bugs/>.
Find the GDB manual and other documentation resources online at:
<http://www.gnu.org/software/gdb/documentation/>.
For help, type "help".
Type "apropos word" to search for commands related to "word"...
Reading symbols from ./test...done.
[New LWP 12462]warning: Could not load shared library symbols for linux-gate.so.1.
Do you need "set solib-search-path" or "set sysroot"?
Core was generated by `./test'.
Program terminated with signal SIGSEGV, Segmentation fault.
#0  0xb765e5d0 in __GI___libc_free (mem=0x8702009) at malloc.c:2916
2916    malloc.c: 没有那个文件或目录.
(gdb) where
#0  0xb765e5d0 in __GI___libc_free (mem=0x8702009) at malloc.c:2916
#1  0x0804852f in main () at main.c:24
(gdb) 

对比可以发现,valgrind给出的检查结果更加精准,更加利于定位问题:

==12005== Invalid free() / delete / delete[] / realloc()
==12005==    at 0x4028F29: free (vg_replace_malloc.c:468)
==12005==    by 0x804850B: main (main.c:18)
==12005==  Address 0x4202029 is 1 bytes inside a block of size 1,024 alloc'd
==12005==    at 0x4029FB0: malloc (vg_replace_malloc.c:291)
==12005==    by 0x80484A8: main (main.c:7)

在有了初步印象之后,接下来一点点学习valgrind的功能。对于一些常用功能,我们会通过python脚本语言自动分析出valgrind检查结果。——这也是通常的CI采用的做法。


3.3 内存检查

。。。



这篇关于valgrind使用方法的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1137255

相关文章

Python通用唯一标识符模块uuid使用案例详解

《Python通用唯一标识符模块uuid使用案例详解》Pythonuuid模块用于生成128位全局唯一标识符,支持UUID1-5版本,适用于分布式系统、数据库主键等场景,需注意隐私、碰撞概率及存储优... 目录简介核心功能1. UUID版本2. UUID属性3. 命名空间使用场景1. 生成唯一标识符2. 数

Java中读取YAML文件配置信息常见问题及解决方法

《Java中读取YAML文件配置信息常见问题及解决方法》:本文主要介绍Java中读取YAML文件配置信息常见问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要... 目录1 使用Spring Boot的@ConfigurationProperties2. 使用@Valu

SpringBoot中如何使用Assert进行断言校验

《SpringBoot中如何使用Assert进行断言校验》Java提供了内置的assert机制,而Spring框架也提供了更强大的Assert工具类来帮助开发者进行参数校验和状态检查,下... 目录前言一、Java 原生assert简介1.1 使用方式1.2 示例代码1.3 优缺点分析二、Spring Fr

Android kotlin中 Channel 和 Flow 的区别和选择使用场景分析

《Androidkotlin中Channel和Flow的区别和选择使用场景分析》Kotlin协程中,Flow是冷数据流,按需触发,适合响应式数据处理;Channel是热数据流,持续发送,支持... 目录一、基本概念界定FlowChannel二、核心特性对比数据生产触发条件生产与消费的关系背压处理机制生命周期

java使用protobuf-maven-plugin的插件编译proto文件详解

《java使用protobuf-maven-plugin的插件编译proto文件详解》:本文主要介绍java使用protobuf-maven-plugin的插件编译proto文件,具有很好的参考价... 目录protobuf文件作为数据传输和存储的协议主要介绍在Java使用maven编译proto文件的插件

Java 方法重载Overload常见误区及注意事项

《Java方法重载Overload常见误区及注意事项》Java方法重载允许同一类中同名方法通过参数类型、数量、顺序差异实现功能扩展,提升代码灵活性,核心条件为参数列表不同,不涉及返回类型、访问修饰符... 目录Java 方法重载(Overload)详解一、方法重载的核心条件二、构成方法重载的具体情况三、不构

SpringBoot线程池配置使用示例详解

《SpringBoot线程池配置使用示例详解》SpringBoot集成@Async注解,支持线程池参数配置(核心数、队列容量、拒绝策略等)及生命周期管理,结合监控与任务装饰器,提升异步处理效率与系统... 目录一、核心特性二、添加依赖三、参数详解四、配置线程池五、应用实践代码说明拒绝策略(Rejected

C++ Log4cpp跨平台日志库的使用小结

《C++Log4cpp跨平台日志库的使用小结》Log4cpp是c++类库,本文详细介绍了C++日志库log4cpp的使用方法,及设置日志输出格式和优先级,具有一定的参考价值,感兴趣的可以了解一下... 目录一、介绍1. log4cpp的日志方式2.设置日志输出的格式3. 设置日志的输出优先级二、Window

SQL中如何添加数据(常见方法及示例)

《SQL中如何添加数据(常见方法及示例)》SQL全称为StructuredQueryLanguage,是一种用于管理关系数据库的标准编程语言,下面给大家介绍SQL中如何添加数据,感兴趣的朋友一起看看吧... 目录在mysql中,有多种方法可以添加数据。以下是一些常见的方法及其示例。1. 使用INSERT I

Ubuntu如何分配​​未使用的空间

《Ubuntu如何分配​​未使用的空间》Ubuntu磁盘空间不足,实际未分配空间8.2G因LVM卷组名称格式差异(双破折号误写)导致无法扩展,确认正确卷组名后,使用lvextend和resize2fs... 目录1:原因2:操作3:报错5:解决问题:确认卷组名称​6:再次操作7:验证扩展是否成功8:问题已解