我正在try 调试泄漏的goroutines(使用Gomega的gleak).当单元测试结束时,一些goroutine"顽固地"坚持不终止,gleak
会转储罪魁祸首及其堆栈跟踪.这些堆栈跟踪中的某些调用在其参数或返回值中甚至包含几个问号,例如:
foo.(*Fooler).Foo(0x40003efa40, {0xeeb638?, 0x40005bc580}, {0x400013a000?, 0x6, 0xd9c3a4?}) at foo.go
相应的接收器功能签名如下:
func (f *Fooler) Foo(context.Context, []string)
我查看了几篇关于"解读golang stack traces"的帖子/文章/问题,至少有How to interpret Go stacktrace篇,但在Go stack traces中没有发现任何问号.我发现解释的例子从未提及任何可疑(?)调用参数或返回值.
那么,堆栈跟踪中出现问号的原因是什么?这是否与传入寄存器的参数有关,并且不能正确恢复堆栈跟踪?