go - 为什么 `go tool pprof` 显示地址而不是函数名?

标签 go pprof

$ go tool pprof pgears.go profilefile.prof
addr2line: crackhdr: unknown header type
Welcome to pprof!  For help, type 'help'.
(pprof) top
Total: 8 samples
       5  62.5%  62.5%        5  62.5% 0000000000028a8b
       1  12.5%  75.0%        1  12.5% 000000000002295c
       1  12.5%  87.5%        1  12.5% 000000000009375a
       1  12.5% 100.0%        1  12.5% 00000000000d278a
       0   0.0% 100.0%        1  12.5% 000000000000252a
       0   0.0% 100.0%        1  12.5% 000000000000259d
       0   0.0% 100.0%        2  25.0% 0000000000017d9e
       0   0.0% 100.0%        2  25.0% 000000000001a2bf
       0   0.0% 100.0%        6  75.0% 000000000001b630
       0   0.0% 100.0%        1  12.5% 0000000000045401
(pprof)

为什么 go tool pprof 显示地址而不是函数名? 来自 http://google-perftools.googlecode.com/svn/trunk/doc/cpuprofile.htmlhttp://blog.golang.org/profiling-go-programs 我们知道它一定是函数名。

或者如何将字节信息更改为函数名?

操作系统:Mac OS 10.9.2
转版本:go1.2 darwin/amd64

最佳答案

pprof 的第一个参数必须是二进制,而不是源文件。

所以你必须编译二进制文件:

$ go build -o ppears

并将其用作pprof的输入:

$ go tool pprof pgears

关于go - 为什么 `go tool pprof` 显示地址而不是函数名?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/22192367/

相关文章:

golang 配置文件与 pprof,如何获得命中数而不是持续时间?

Golang pprof 完整调用图

go - Go程序中如何使用pprof

go - 使用GC负责90%的CPU时间

postgresql - 单元测试 Postgres 数据库连接 golang

go - 解析 plist xml

开始,按回车键继续

go - golang struct中tag有什么用?

regex - 根据空格和括号从字符串中提取单词

go - 如何分析 goroutines 的数量