gprof性能分析

gprof用法

1 命令格式

gprof官方手册
gprof [可执行文件] [gmon.out文件] [其它参数]

方括号中的内容可以省略。如果省略了“可执行文件”,gprof会在当前目录下搜索a.out文件作为可执行文件,而如果省略了gmon.out文件,gprof也会在当前目录下寻找gmon.out。其它参数可以控制gprof输出内容的格式等信息。最常用的参数如下:

  • -b 不再输出统计图表中每个字段的详细描述。
  • -p 只输出函数的调用图(Call graph的那部分信息)。
  • -q[symspec] print call graph only for matching symbols and their children.
  • -e Name 不再输出函数Name 及其子函数的调用图(除非它们有未被限制的其它父函数)。可以给定多个 -e 标志。一个 -e 标志只能指定一个函数。
  • -E Name 不再输出函数Name 及其子函数的调用图,此标志类似于 -e 标志,但它在总时间和百分比时间的计算中排除了由函数Name 及其子函数所用的时间。
  • -f Name 输出函数Name 及其子函数的调用图。可以指定多个 -f 标志。一个 -f 标志只能指定一个函数。
  • -F Name 输出函数Name 及其子函数的调用图,它类似于 -f 标志,但它在总时间和百分比时间计算中仅使用所打印的例程的时间。可以指定多个 -F 标志。一个 -F 标志只能指定一个函数。-F 标志覆盖 -E 标志。
  • -z 显示使用次数为零的例程(按照调用计数和累积时间计算)
  • –demangle[=style]
  • –no-demangle These options control whether C++ symbol names should be demangled when printing output. The default is to demangle symbols.

2 例子

./darknet classifier predict cfg/imagenet1k.data cfg/darknet19.cfg darknet19.weights data/dog.jpg

gprof -b ./darknet gmon.out > g1.txt

# 过滤掉系统函数等
cat output_serial.txt | grep -v "__gnu" | grep -v "__libc" | grep -v "_GLOBAL" | grep -v "__static" > output_serial_core.txt

python gprof2dot.py g1.txt | dot -Tpng -o g1.png

# 脚本
yhrun -p thcp1 -N 1 -n 1 ./$1

gprof $1 gmon.out > $2.txt

python3 gprof2dot.py $2.txt | dot -Tpng -o $2.png

cat $2.txt | grep -v "__gnu" | grep -v "__libc" | grep -v "_GLOBAL" | grep -v "__static" > $2_core.txt
  • 2
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值