为什么 docall 在 singleflight 中使用 gopanic?

whu*_*sol 6 go

我最近在阅读 singleflight 源代码,对第 158 行感到困惑。

if len(c.chans) > 0 {
    go panic(e)
    select {} // Keep this goroutine around so that it will appear in the crash dump.
} else {
    panic(e)
}
Run Code Online (Sandbox Code Playgroud)

使用channel时为什么要使用gopanic而不是直接panic?第129行使用 go docall ,在这个方法中panic,上层无法恢复,所以go panic应该没有意义了吧?

再者,如果有并发请求,panic后通道仍然没有写入,其他goroutine不也会阻塞吗?如果有好心人阅读并解答,我非常感激~

了解设计含义

Bur*_*dar 5

go panic将导致无法恢复的恐慌。恐慌和select之后的事情确保恐慌的 goroutine 出现在堆栈转储中,因此您可以查看堆栈转储并意识到不应该发生的情况已经发生。

这只是确保您不会无意中从不应恢复的内容中恢复的一种方法。