Heim >Datenbank >MySQL-Tutorial >cygwin环境下gprof+gprof2dot+dot生成函数关系结构图

cygwin环境下gprof+gprof2dot+dot生成函数关系结构图

WBOY
WBOYOriginal
2016-06-07 15:32:101496Durchsuche

在linux环境下利用gcc/g编译链接代码的时候,加入-pg选项,在执行文件后就会生成gmon.out,gmon.out记录了函数在cpu运行的时间和被哪些函数调用的次数,关于gprof的使用和原理说明可以参数这两篇文章《linux下的程序分析工具——gprof 》、《Linux性能评测工

     在linux环境下利用gcc/g++编译链接代码的时候,加入-pg选项,在执行文件后就会生成gmon.out,gmon.out记录了函数在cpu运行的时间和被哪些函数调用的次数,关于gprof的使用和原理说明可以参数这两篇文章《linux下的程序分析工具——gprof 》、《Linux性能评测工具之一:gprof篇》。步骤如下:

      1.gcc -Wall -pg test.c -o test

      2../test.exe (由于我是在windows环境下用cygwin的,所以生成有exe后缀)

      3.gprof -b ./test.exe >report.txt

     生成的flat profile和call graph如图1。

 cygwin环境下gprof+gprof2dot+dot生成函数关系结构图

图1

        从图1中可以看出gprof生成的都是文字描述,我们可以利用gprof2dot.py脚本把数据转化成dot格式,再利用dot生成一张函数关系图。

        cygwin配置环境要求下:

        1.安装python。

        2.gprof2dot.py(网上有得下载),下载后放在/bin/目录就可以了。

        3.安装graphviz,直接搜索graphviz,如图2,然后安装。

cygwin环境下gprof+gprof2dot+dot生成函数关系结构图

图2

       gprof2dot默认是部分函数调用图,如果要显示全部的函数调用关系,可以用gprof2dot -n0 -e0。默认的设置可以直接参数gprof2dot.py,截图如图3。

cygwin环境下gprof+gprof2dot+dot生成函数关系结构图

图3

       安装好之后,执行如下命令:

       gprof -b ./test.exe|gprof2dot.py |dot -Tpng -o test.png或者

       python /bin/gprof2dot.py report.txt | dot -Tpng -o test.png

       这就生成了一张函数关系图了,如图4。

     cygwin环境下gprof+gprof2dot+dot生成函数关系结构图

图4

        以上都是今天下午的学习成果,总结了网上一些文章所说的和自己动手实践成果。但是我一点都不懂graphviz和dot,这是值得我拓展的地方!

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn