使用valgrind的callgrind工具进行多线程性能分析
2015-06-03 17:25
344 查看
简介valgrind是开源的性能分析利器。 根据它的文档,可以用它来检查内存泄漏等问题,还可以用来生成函数的调用图,就这两个功能就足够有吸引力了。
本文主要是介绍如何使用valgrind的callgrind工具进行性能分析。分析过程
其中 ./exproxy就是我们要分析的程序。执行完毕后,就会在当前目录下生成一个文件。文件名为“callgrind.out.进程号”。如,callgrind.out.31113。注意,对于daemon进程的调试,不要通过kill -9方式停止。如果你调试的程序是多线程,你也可以在命令行中加一个参数 –separate-threads=yes。这样就会为每个线程单独生成一个性能分析文件。如下:
生成的文件除了callgrind.out.31113外,还会多出一些子线程的文件。文件名如下:
callgrind.out.31113-01 callgrind.out.31113-02 callgrind.out.31113-03
脚本可以点此下载。脚本使用方式如下:
通过图形,我们可以很直观的知道那段程序执行慢,并且了解相关调用关系。来源:http://www.bo56.com/%E4%BD%BF%E7%94%A8valgrind%E7%9A%84callgrind%E5%B7%A5%E5%85%B7%E8%BF%9B%E8%A1%8C%E5%A4%9A%E7%BA%BF%E7%A8%8B%E6%80%A7%E8%83%BD%E5%88%86%E6%9E%90/
本文主要是介绍如何使用valgrind的callgrind工具进行性能分析。分析过程
使用callgrind工具生成性能分析数据
命令格式如下:callgrind.out.31113-01 callgrind.out.31113-02 callgrind.out.31113-03
把callgrind生成的性能数据转换成dot格式数据
可以使用gprof2dot.py脚本,把callgrind生成的性能分析数据转换成dot格式的数据。方便使用dot把分析数据图形化。脚本可以点此下载。脚本使用方式如下:
使用dot把数据生成图片
命令格式如下:生成的图片示例
通过图形,我们可以很直观的知道那段程序执行慢,并且了解相关调用关系。来源:http://www.bo56.com/%E4%BD%BF%E7%94%A8valgrind%E7%9A%84callgrind%E5%B7%A5%E5%85%B7%E8%BF%9B%E8%A1%8C%E5%A4%9A%E7%BA%BF%E7%A8%8B%E6%80%A7%E8%83%BD%E5%88%86%E6%9E%90/
相关文章推荐
- Android 开源框架Universal-Image-Loader完全解析(三)---源代码解读
- srm 531
- js数字或字母的正则表达式
- 利用libvirt命令动态挂载数据盘的方法
- Android视频下载地址都有哪些?
- Django学习(六) 模板
- 好贴地址
- 配置,编译
- 网狐框架二次开发常见bug问题汇总
- jquery 常用选择器及方法
- opensips使用加密密码认证
- SAT阅读强化
- Android 开源框架Universal-Image-Loader完全解析(二)--- 图片缓存策略详解
- Java高级编程:深入剖析ThreadLocal
- Auto Layout 使用心得
- android_adb命令
- struts2加载struts2常量顺序
- 5分钟将OSC Android源码从Eclipse项目转化为Android studio项目
- 程序中执行外部exe
- 判断拓展名