使用gprof2dot和graphivz生成程序运行调用图

gprof2dot是一个将gprof生成的输出转换为dot脚本的工具。通过给定一个gprof的输出文件,将其转换为生成程序调用图的dot脚本。dot脚本可以生成图像来进行查看。

1、下载gprof2dot工具

gprof2dot工具由JoséFronseca维护,并托管在Google代码(http://code.google.com/p/jrfonseca/w/list),但是这个已经无法访问了。这里提供一个github的地址https://github.com/jrfonseca/gprof2dot.git

git clone https://github.com/jrfonseca/gprof2dot.git

这个工具需要python环境的支持,请提前安装好python3

2、使用gprof生成概要分析数据

2.1 gprof简介

Gprof 是GNU gnu binutils工具之一,默认情况下linux系统当中都带有这个工具。

    1. 可以显示“flat profile”,包括每个函数的调用次数,每个函数消耗的处理器时间。
    1. 可以显示“Call graph”,包括函数的调用关系,每个函数调用花费了多少时间。
    1. 可以显示“注释的源代码”--是程序源代码的一个副本,标记有程序中每行代码的执行次数。

2.2 使用gprof生成分析数据

1、在编译的时候使用-pg选项,可以写入makefile中。(链接时不需要)

# 普通程序编译
$ gcc -pg -g source.c -o binary
# cuda程序编译
$ nvcc -Xcompiler“-g -pg”-g -pg -arch = sm_20 source.cu -o binary

2、执行编译出的程序。

执行方式与没有加pg选项前是一样的,执行后将在程序运行目录下生成gmon.out文件。这是一个二进制文件,需要进一步分析生成文本文件。如果已经存在了gmon.out文件,将会被覆盖。

./binary	# 必须先运行一遍生成gmon.out文件,后面才能使用gprof工具继续操作

3、用gprof工具生成概要分析数据文件。

$ gprof ./binary> gprof_output.txt

3、生成调用图

配置好gprof2dot运行环境后,就可以使用其来生成dot脚本。

$ graph2dot.py gprof_output.txt> call_graph.dot

我这里是直接使用git克隆下来的,提前安装好了python3和graphivz`,所以直接运行即可。

4、生成可视化的图形

这里需要安装好Graphivz软件。

Windows下可以直接下载安装包安装,或者下载编写版本

Linux下可以使用下面命令直接安装

# debian系列
sudo apt install graphivz
# Archlinux系列
sudo pacman -S graphivz
# fedora
sudo dnf install graphivz

然后使用dot命令将前面生成的call_graph.dot文件转换为图像文件。

生成png文件

$ dot -Tpng call_graph.dot -o call_graph.png

生成PostScript文件

$ dot -Tps call_graph.dot -o call_graph.ps

如果要生成其他格式的图像,可以使用-T选项指定,支持eps/gif/jpeg/ps/svg/png/ps2/svgz等格式/

如果需要对布局引擎进行选择,可以使用-K进行指定,支持circo/dot/fdp/neato/nop/nop1/nop2/osage/patchwork/sfdp/twopi等。

例如,生成png图像,使用fdp布局引擎的命令如下:

$ dot -Tsvg -Kfdp call_graph.dot -o call_graph.svg

注:布局引擎可以根据自己的喜好选择,个人倾向使用fdp。默认是上下方向布局的,可以在call_graph.dot中添加一行rankdir=LR改为左向右方向布局。

参考

Linux性能評測工具之一:gprof篇

Linux下性能分析工具和内存泄露检测工具的简介(Valgrind和gprof)

gprof_call-graph_visualization

使用gprof2dot和graphivz生成程序运行调用图的更多相关文章

  1. CodeViz产生函数调用图

    一.安装过程   1.CodeViz的安装 0).确认你已经安装Graphviz[ http://www.graphviz.org/] 1).下载CodeViz.[ http://www.csn.ul ...

  2. calltree看代码调用图

    calltree是在linux下面看c代码(尤其是复杂的内核代码)的神器. 推荐  calltree+vim + ctags + cscope + taglist [ vim: 搭建vim看代码的环境 ...

  3. Python - 运行流程图, call graph, 调用图

    解决方案 pycallgraph(感觉直接用pycallgraph grahviz命令生成的图并不是我想要的) 如何去阅读并学习一些优秀的开源框架的源码? - mailto1587的回答 - 知乎 h ...

  4. Servlet第二篇【Servlet调用图、Servlet细节、ServletConfig、ServletContext】

    Servlet的调用图 前面我们已经学过了Servlet的生命周期了,我们根据Servlet的生命周期画出Servlet的调用图加深理解 Servlet的细节 一个已经注册的Servlet可以被多次映 ...

  5. calltree+graphviz 绘出项目函数调用图

    install calltree: download from http://linux.softpedia.com/progDownload/calltree-Download-971.html f ...

  6. tracef 安装 跟踪 函数调用图

    http://www.prevanders.net/dwarf.html redhat 5.4 tar -zxvf libdwarf-20140519.tar.gz [root@localhost d ...

  7. 【转】doxygen+graphviz生成工程中的类继承树及函数调用图

    转自----hequn8128 在阅读代码量比较多的项目时,类的继承树和函数调用图能够直观地向我们显示类之间或者函数之间的各种关系,方便我们了解程序的整体框架,很多时候可以起到事半功倍的作用.这里尝试 ...

  8. JAVA call graphs JAVA调用图

    https://github.com/gousiosg/java-callgraph Programs for producing static and dynamic (runtime) call ...

  9. win32内存调用图

    https://msdn.microsoft.com/en-us/library/ms810603.aspxhttps://www.codeproject.com/Articles/14525/Hea ...

随机推荐

  1. 用Razor語法寫範本-RazorEngine組件介紹

    最近剛好有要寫寄Email的程式,在代碼中寫HTML覺得很呆,抽出代碼外寫到txt或html檔當範本,由程式執行時在載入檔案時用Regex換關鍵字又覺得不夠好用,而且因為有時會有要判斷一些條件,就會寫 ...

  2. 样条之CatmullRom

    所谓样条曲线是指给定一组控制点而得到一条曲线,曲线的大致形状由这些点予以控制,一般可分为插值样条和逼近样条两种,插值样条通常用于数字化绘图或动画的设计,逼近样条一般用来构造物体的表面.CatmullR ...

  3. 非常好的课程,尤其是有NLP方向的内容,好好学习

    课程地址如下: https://mooc.study.163.com/smartSpec/detail/1001319001.htm 有一个非常好的笔记: https://github.com/fen ...

  4. java的关于流程结构做的几个案例

    最近在学习中,做了一个java的几个案例,主要是九九乘法口诀,实心菱形和空心菱形的算法,模拟彩票程序以及BMI的测试标准等小案例. 一:九九乘法表 /** * 九九乘法口诀 */ public sta ...

  5. 【StatLearn】统计学习中knn算法实验(2)

    接着统计学习中knn算法实验(1)的内容 Problem: Explore the data before classification using summary statistics or vis ...

  6. CSV 数字转化文本

    最近遇到一个Bug问题,csv 数值转化为文本的问题. 数据如下: 运行效果 如下: 大家看到“01720” 前面的0 没有显示出来.怎样才能显示出来了, 这里的csv文件格式也没有什么问题.后来找到 ...

  7. Zindex和png

    Z轴在元素设置position为absolute或relative后被激活,起大小由z-index设置,z-index越大,元素位置越靠上.如果多个元素的z-index值相同,那么html标签中后出现 ...

  8. AVL树原理及实现 +B树

    1. AVL定义 AVL树是一种改进版的搜索二叉树.对于一般的搜索二叉树而言,如果数据恰好是按照从小到大的顺序或者从大到小的顺序插入的,那么搜索二叉树就对退化成链表,这个时候查找,插入和删除的时间都会 ...

  9. 如何移除EFI system partition?

    莫名其妙, 在我的服务器上出现了这样一种分区, 上面写着EFI system, 删也删不掉, 因为删除分区的菜单是灰掉的. 找到了这篇文章, 成功的删掉了这个烦人的分区. 整个过程记录如下:   参考 ...

  10. ORM数据库框架 SQLite ORMLite MD

    Markdown版本笔记 我的GitHub首页 我的博客 我的微信 我的邮箱 MyAndroidBlogs baiqiantao baiqiantao bqt20094 baiqiantao@sina ...