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