在Go中如何转储一个方法的GOSSAFUNC图

开发 后端
Go 编译器的 SSA 后端包含一种工具,可以生成编译阶段的 HTML 调试输出。这篇文章介绍了如何为函数和方法打印 SSA 输出。

[[331326]]

Go 编译器的 SSA 后端包含一种工具,可以生成编译阶段的 HTML 调试输出。这篇文章介绍了如何为函数方法打印 SSA 输出。

让我们从一个包含函数、值方法和指针方法的示例程序开始:

  1. package main
  2.  
  3. import (
  4. "fmt"
  5. )
  6.  
  7. type Numbers struct {
  8. vals []int
  9. }
  10.  
  11. func (n *Numbers) Add(v int) {
  12. n.vals = append(n.vals, v)
  13. }
  14.  
  15. func (n Numbers) Average() float64 {
  16. sum := 0.0
  17. for _, num := range n.vals {
  18. sum += float64(num)
  19. }
  20. return sum / float64(len(n.vals))
  21. }
  22.  
  23.  
  24. func main() {
  25. var numbers Numbers
  26. numbers.Add(200)
  27. numbers.Add(43)
  28. numbers.Add(-6)
  29. fmt.Println(numbers.Average())
  30. }

通过 GOSSAFUNC 环境变量控制 SSA 调试输出。此变量含有要转储的函数的名称。这不是函数的完全限定名。对于上面的 func main,函数名称为 main 而不是 main.main

  1. % env GOSSAFUNC=main go build
  2. runtime
  3. dumped SSA to ../../go/src/runtime/ssa.html
  4. t
  5. dumped SSA to ./ssa.html

在这个例子中,GOSSAFUNC=main 同时匹配了 main.main 和一个名为 runtime.main 的函数。[1]这有点不走运,但是实际上可能没什么大不了的,因为如果你要对代码进行性能调整,它就不会出现在 func main 中的巨大的意大利面块中。

你的代码更有可能在方法中,你可能已经看到这篇文章,并寻找能够转储方法的 SSA 输出。

要为指针方法 func (n *Numbers) Add 打印 SSA 调试,等效函数名为 (*Numbers).Add[2]

  1. % env "GOSSAFUNC=(*Numbers).Add" go build
  2. t
  3. dumped SSA to ./ssa.html

要为值方法 func (n Numbers) Average 打印 SSA 调试,等效函数名为 (*Numbers).Average即使这是一个值方法

  1. % env "GOSSAFUNC=(*Numbers).Average" go build
  2. t
  3. dumped SSA to ./ssa.html

  1. 如果你没有从源码构建 Go,那么 runtime 软件包的路径可能是只读的,并且可能会收到错误消息。请不要使用 sudo 来解决此问题。 

  2. 请注意 shell 引用 。

 

责任编辑:庞桂玉 来源: Linux中国
相关推荐

2018-07-16 08:40:08

Linux段错误C++

2022-05-22 13:55:30

Go 语言

2021-07-02 07:18:19

Goresults通道类型

2023-02-26 01:37:57

goORM代码

2021-01-04 09:12:31

集合变量

2022-09-20 08:43:37

Go编程语言Web

2022-02-21 08:15:15

Go项目语言

2020-02-19 08:26:31

凭证转储攻击

2019-12-27 15:05:51

Python类方法装饰器

2020-09-29 07:24:14

Python字典数据

2024-08-12 08:33:05

2024-03-19 14:15:48

Go程序os.Exit()

2015-10-12 15:50:07

PaaS云平台开发go

2020-08-31 08:51:10

Linux转储文件内存

2022-02-10 22:34:51

对象JVM收集器

2022-04-13 09:30:00

C++二分图图着色

2012-08-01 14:29:03

IBMdW

2018-08-19 09:45:19

Windows 10蓝屏死机转储文件

2020-10-14 06:18:20

Golang字符串数组

2021-09-11 22:32:26

Go 绑定 Host
点赞
收藏

51CTO技术栈公众号