C程序 性能分析

编译配置分析

使用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

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值