在 Go 中调试恐慌错误时,遇到神秘的“恐慌堆栈跟踪中的未知字段”并不罕见。为了解开这个谜团,让我们深入研究堆栈跟踪的复杂性。
在提供的代码片段中:
package main func F(a int) { panic(nil) } func main() { F(1) }
运行程序会显示一个紧急堆栈跟踪:
panic: nil goroutine 1 [running]: main.F(0x1, 0x10436000) /tmp/sandbox090887108/main.go:4 +0x20 main.main() /tmp/sandbox090887108/main.go:8 +0x20
与 F(0x1) 一起提到的神秘值 0x10436000 有何意义?
值 0x10436000 不是函数的第二个参数。相反,它表示作为第一个参数传入的原始数据值,表示为指针大小的值。这是 Playground 架构的结果,它具有 64 位字长和 32 位指针 (GOARCH=amd64p32)。
在traceback.go 文件中,通过根据指针大小迭代访问参数来打印值:
for i := uintptr(0); i < frame.arglen/sys.PtrSize; i++ {
这意味着由于单词大小是游乐场中指针大小的两倍,因此在每个帧的参数中打印值对。
进一步说明:
func F(a uint8) { panic(nil) }
调用 F(1) 结果在:
main.F(0x97301, 0x10436000)
仅使用 64 位字的前 8 位(本例中为 1),而其余部分未使用。
main.F(0x100000001, 0xc400000001)
这三个参数占用两个字,并打印额外未使用的值。
func F(a int64) (int, int)
在 amd64 上,堆栈帧参数将显示为:
main.F(0xa, 0x1054d60, 0xc420078058)
第一个单词是 for参数,另外两个用于未初始化的返回值。
以上是Go 恐慌堆栈跟踪中的“未知字段”有何意义?我们如何解码回溯中的参数?的详细内容。更多信息请关注PHP中文网其他相关文章!