我正在尝试调试泄漏的goroutines (使用Gomega的漏气)。当单元测试结束时,一些goroutines“顽固地”坚持不终止,gleak用它们的堆栈跟踪转储罪魁祸首。这些堆栈跟踪中的某些调用在其参数或返回值中甚至包含几个问号,例如:
foo.(*Fooler).Foo(0x40003efa40, {0xeeb638?, 0x40005bc580}, {0x400013a000?, 0x6, 0xd9c3a4?}) at foo.go相应的接收函数签名如下:
func (f *Fooler) Foo(context.Context, []string)我检查了几篇关于“解释戈朗堆栈跟踪”的帖子/文章/问题,尤其是如何解释Go堆栈跟踪,但是在Go堆栈跟踪中没有发现任何提到问号的地方。我发现解释的例子从来没有提到任何有问题的(?)调用参数或返回值。
那么,堆栈跟踪中出现问号的原因是什么呢?这是否与在寄存器中传递的args有关,并且不能正确地恢复堆栈跟踪?
发布于 2022-05-23 14:32:01
来自https://go.dev/doc/go1.18#runtime:
Go 1.17通常改进了堆栈跟踪中参数的格式,但可能会为寄存器中传递的参数打印不准确的值。在Go 1.18中通过打印问号(?)改进了这一点。在每个可能不准确的值之后。
https://stackoverflow.com/questions/72344585
复制相似问题