glob.func 在 pprof 堆配置文件中
glob.func in pprof heap profiles
在使用 go tool pprof
进行堆分析时,我看到了一些条目,例如 github.com/anacrolix/utp.glob.func1
。这与我能看到的任何命名函数都不对应,我认为它是一个闭包。 glob
指的是什么?我怎样才能将这样的名称关联到适当的函数?
glob
指的是全局环境,func1
指的是匿名函数。所以它应该引用一些全局匿名函数。检查this example及其恐慌信息:
示例:
package main
import (
"fmt"
)
var (
p = func() string {
panic("a")
return "asdf"
}()
)
func main() {
fmt.Println(p)
}
紧急信息:
panic: a
goroutine 1 [running]:
panic(0x128360, 0x1040a120)
/usr/local/go/src/runtime/panic.go:464 +0x700
main.glob.func1(0x0, 0x0)
/tmp/sandbox715198144/main.go:9 +0x80
main.init()
/tmp/sandbox715198144/main.go:12 +0xa0
在使用 go tool pprof
进行堆分析时,我看到了一些条目,例如 github.com/anacrolix/utp.glob.func1
。这与我能看到的任何命名函数都不对应,我认为它是一个闭包。 glob
指的是什么?我怎样才能将这样的名称关联到适当的函数?
glob
指的是全局环境,func1
指的是匿名函数。所以它应该引用一些全局匿名函数。检查this example及其恐慌信息:
示例:
package main
import (
"fmt"
)
var (
p = func() string {
panic("a")
return "asdf"
}()
)
func main() {
fmt.Println(p)
}
紧急信息:
panic: a
goroutine 1 [running]:
panic(0x128360, 0x1040a120)
/usr/local/go/src/runtime/panic.go:464 +0x700
main.glob.func1(0x0, 0x0)
/tmp/sandbox715198144/main.go:9 +0x80
main.init()
/tmp/sandbox715198144/main.go:12 +0xa0