Valgrind 使用入门

1. 工具简介:

Valgrind 是一套类似于 gprof 的动态检测的工具集,由于使用方便,不需修改目标程序源码,输出清晰图文并茂等优势,常被用作后台(特别是linux后台)服务内存泄漏检测、性能打点、竞态检测等。

2. 工具安装:

a. 去官方网站 http://valgrind.org/downloads/current.html 下载最新安装包,如 valgrind 3.13.0 (tar.bz2) 解压;

b. 常规源码编译安装:./autogen.sh; ./configure; make; make install;

c. 安装成功 valgrind --version 输出版本号;

3. 工具使用:

3.1 内存泄漏检测:

a. 正常编译目标程序 (如 g++ -g -o valgrind_tst main.cpp),官方推荐加上 -g 选项;

b. valgrind --tool=memcheck --leak-check=full --log- file=memchk.log valgrind_tst [Your progame option];

c. --tool=memcheck 表示使用工具集中的内存检测,其他选项参考 valgrind -h;

d. 特别的 --trace-children = yes 开启这个选项将使 valgrind 追踪到子进程,但据说不是很好用,所以我一般将服务设置为前台运行,如果你的后台服务(daemon 进程)无法设置前台运行,可以尝试这个选项;

e. 结果输出,直接 vi memchk.log(由命令中的 --log-file 指定)查看:

结果中比较重要的是:

definitely lost: 确定有内存泄漏,表示在程序退出时,该内存无法回收,也没指针指向该内存(首地址);

indirectly lost: 间接内存泄漏,比如结构体中定义的指针指向的内存无法回收;

possibly lost: 可能出现内存泄漏,比如程序退出时,没有指针指向一块内存的首地址了,但由其他某个指针能推算出首地址;

still reachable: 程序没主动释放内存,在退出时候该内存仍能访问到,比如全局 new 的对象没 delete,由于操作系统会回收,所以此类问题可忽略;

最严重的是 definitely lost 和 indirectly lost,检测结果文件中已给出了具体函数和源文件。

3.2 性能检测(调优):

a. 正常编译目标程序同上;

b. valgrind --tool=callgrind -v Your_Programme [Your_Programe_Option];

c. --tool=callgrind 表示使用调用检测工具,同样,建议在前台运行;

d. 由于 callgrind 的原理是时间点采样,所以被测程序最好在合适的压力下运行合适长的时间;

e. 查看结果,运行完后,将输出 callgrind.out.PID 文件,该文件可被 gprof2dot 等工具解析转化为 dot,再由 dot 转化为图片输出,也可以直接用 callgrind_annotate 直接解析打印,但最方便的是使用图形工具解析,如 windows 上的 qcachegrind;

f. qcachegrind 安装略,以下是 qcachegrind 打开上述 callgrind.out.PID 文件的效果:

左边列出了调用parts、调用栈 cost 排序等,右边列出了所有调用者、被调用者以及调用图等。

g. 分析程序的性能损耗在哪,可以选择左侧 Flat File --> group by ELF object,找到感兴趣的 object 文件:

h. Self表示自身执行的耗时,Incl表示包含调用函数的总耗时,选择感兴趣的函数,在右边可查看该函数的调用关系图:

i. 根据耗时分布找到程序的性能瓶颈,针对性的优化,关于 qcachegrind 的详细说明,可查阅官网 http://kcachegrind.sourceforge.net/html/Home.html

5. 最后:

在 callgrind 的调用图中发现这个:

它是什么呢,有什么用呢?

在下篇文章《ld_XXXX.so 在你不小心 rm -f /* 时的作用》在聊 :D

原创声明,本文系作者授权云+社区-专栏发表,未经许可,不得转载。

如有侵权,请联系 yunjia_community@tencent.com 删除。

编辑于

王纯的专栏

1 篇文章1 人订阅

我来说两句

0 条评论
登录 后参与评论

相关文章

来自专栏守望轩

Visual Studio 2008 每日提示(三)

#021、 调整字符、词或行的顺序 原文地址:http://blogs.msdn.com/saraford/archive/2007/08/23/did-yo...

2583
来自专栏机器之心

资源 | Parris:机器学习算法自动化训练工具

3269
来自专栏高性能服务器开发

libevent源码深度剖析十一 时间管理

(1)libevent源码深度剖析一 序 (2)libevent源码深度剖析二 Reactor模式 (3)libevent源码深度剖析三 libevent基本使...

571
来自专栏Python Web学习记录及整理

HTML学习记录及整理

<!DOCTYPE ”此文仅为个人学习的知识梳理,权威且更详细的内容请查阅w3school。“>

4068
来自专栏nummy

使用doctest进行测试

python中的doctest可以运行文档中嵌入的例子,并验证它们能否生成所期望的结果,从而对源代码进行测试。

531
来自专栏积累沉淀

JavaScript 事件基础补充

JavaScript事件是由访问Web页面的用户引起的一系列操作,例如:用户点击。当用户执行某些操作的时候,再去执行一系列代码。 一.事件介绍 JavaScri...

1835
来自专栏小狼的世界

利用PHP的Popen实现RRDTOOL作图的动态输出

最近看了一下RRDTOOL如何作图,语法确实比较繁琐,但不是太难。命令行下执行的时候,每次都需要输出成为一个文件。我们希望做一个应用,能够动态生成图表,看了看C...

1003
来自专栏DannyHoo的专栏

Xcode真机调试包的路径

版权声明:本文为博主原创文章,未经博主允许不得转载。 https://blog.csdn.net/u010105969/article/details/...

851
来自专栏技术分享

log4net 自定义Layout日志字段

最近在使用log4net的时候有一个简单的需求,就是自定义个格式化输出符。这个输出符是专门用来帮我记录下业务ID、业务类型的。比如,“businessID:32...

590
来自专栏深度学习之tensorflow实战篇

python 中输出字符的颜色控制属性

在开发项目过程中,为了方便调试代码,经常会向stdout中输出一些日志,默认的这些日志就直接显示在了终端中。而一般的应用服务器,第三方库,甚至服务器的一些通告也...

3109

扫码关注云+社区