编译配置分析
使用gprof
进行分析
以CMAKE项目为例
首先配置CMakeLists.txt
,编译时增加-pg
参数
SET(CMAKE_CXX_FLAGS "${CMAKE_CXX_FLAGS} -pg")
SET(CMAKE_C_FLAGS "${CMAKE_C_FLAGS} -pg")
SET(CMAKE_EXE_LINKER_FLAGS "${CMAKE_EXE_LINKER_FLAGS} -pg")
SET(CMAKE_SHARED_LINKER_FLAGS "${CMAKE_SHARED_LINKER_FLAGS} -pg")
使用编译程序,例如
demo.exe
运行程序
demo.exe
由于增加了-pg
参数,在运行demo.exe
会在执行目录下生成gmon.out
运行结束目录包含后如下内容
demo.exe
gmon.out
运行gprof分析,并将分析结果存储到proff.txt
中
gprof demo.exe gmon.out > proff.txt
可视化
为了便于分析通常会使用gprof2dot
工具生成可视化的图表
gprof2dot的使用安装请见 https://github.com/jrfonseca/gprof2dot
该工具依赖,按照官网说明安装就可以:
- python3
- Graphviz
如果本机没有pip可以安装一下pip,或者直接下载他的脚本,我这里就使用pip安装
pip install gprof2dot
在刚才的目录中运行下面命令生成可视化的图表,注意参数这里我们需要填写刚才生成的proff.txt
文件
gprof2dot -n0 -e0 proff.txt | dot -Tpng -o output.png
最终结果会存储为名为 output.png
的PNG图片
如果在运行过程中出现下面错误
那么请检查一下你的proff.txt
文件的编码格式,如果不是UTF-8 那么请装换为UTF-8再尝试。
参考文献
[1]. 博客园 . Linux c++ 性能分析工具gprof . youxin . 2020.3 . https://www.cnblogs.com/youxin/p/12398357.html
[2]. github . jrfonseca . gprof2dot . https://github.com/jrfonseca/gprof2dot
[3]. CSND . cmake使用gprof输出数据为空 . sgdd123 . 2018.7 . https://blog.csdn.net/sgdd123/article/details/80929708