网络包导入和死锁检测的相互作用
在 Go 程序中,如果程序运行时通道操作阻塞,则程序最终会收到“死锁”错误。但是,当导入 net 包时,行为会发生变化。
有问题的代码片段:
package main
import (
"fmt"
"net/http"
)
func main() {
var ch = make(chan int)
ch 如果没有导入net/http包,程序会退出并出现“死锁”错误。这是因为通道操作(发送到无缓冲的通道)永远阻塞,并且没有其他 goroutine 运行来执行异步操作,从而允许死锁检测器识别问题。
但是,当 net/http包导入后,程序不会死锁。这是因为导入 net 包会启动后台轮询 Goroutines,从而有效地禁用死锁检测器。
net 包包含管理网络连接的功能,并且它使用 Goroutines 异步处理连接。即使当前没有建立或处理任何 HTTP 连接,这些后台轮询 Goroutine 也会继续运行,这使得程序对于死锁检测器来说是非阻塞的。因此,尽管通道操作被阻止,但程序不会因“死锁”错误而退出。
此行为已在 GitHub 问题 https://github.com/golang/go/issues 中讨论过/12734.
免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。
Copyright© 2022 湘ICP备2022001581号-3