在Go中如何轉儲一個方法的GOSSAFUNC圖
Go 編譯器的 SSA 后端包含一種工具,可以生成編譯階段的 HTML 調試輸出。這篇文章介紹了如何為函數和方法打印 SSA 輸出。
讓我們從一個包含函數、值方法和指針方法的示例程序開始:
package mainimport ("fmt")type Numbers struct {vals []int}func (n *Numbers) Add(v int) {n.vals = append(n.vals, v)}func (n Numbers) Average() float64 {sum := 0.0for _, num := range n.vals {sum += float64(num)}return sum / float64(len(n.vals))}func main() {var numbers Numbersnumbers.Add(200)numbers.Add(43)numbers.Add(-6)fmt.Println(numbers.Average())}
通過 GOSSAFUNC 環境變量控制 SSA 調試輸出。此變量含有要轉儲的函數的名稱。這不是函數的完全限定名。對于上面的 func main,函數名稱為 main 而不是 main.main。
% env GOSSAFUNC=main go buildruntimedumped SSA to ../../go/src/runtime/ssa.htmltdumped SSA to ./ssa.html
在這個例子中,GOSSAFUNC=main 同時匹配了 main.main 和一個名為 runtime.main 的函數。[1]這有點不走運,但是實際上可能沒什么大不了的,因為如果你要對代碼進行性能調整,它就不會出現在 func main 中的巨大的意大利面塊中。
你的代碼更有可能在方法中,你可能已經看到這篇文章,并尋找能夠轉儲方法的 SSA 輸出。
要為指針方法 func (n *Numbers) Add 打印 SSA 調試,等效函數名為 (*Numbers).Add:[2]
% env "GOSSAFUNC=(*Numbers).Add" go buildtdumped SSA to ./ssa.html
要為值方法 func (n Numbers) Average 打印 SSA 調試,等效函數名為 (*Numbers).Average,即使這是一個值方法:
% env "GOSSAFUNC=(*Numbers).Average" go buildtdumped SSA to ./ssa.html
-
如果你沒有從源碼構建 Go,那么
runtime軟件包的路徑可能是只讀的,并且可能會收到錯誤消息。請不要使用sudo來解決此問題。 -
請注意 shell 引用 。






























