主 Goroutine 的困境:睡觉还是退出?
开发人员经常遇到需要保持 Go 项目持续运行的情况,就像永恒的火焰一样,永远不会消失。相反,在某些情况下,人们希望优雅地结束程序的执行。本文探讨了适用于这些场景的选项。
“休眠”主 Goroutine
为了使主 Goroutine 处于休眠状态,存在几种结构,可以有效地阻止其执行,而无需消耗CPU资源。考虑以下示例:
选择不带大小写的:
select{}
从空接收通道:
<-make(chan int)
从零通道接收:
<-(chan int)(nil)
发送到零通道:
(chan int)(nil) <- 0
锁定锁定的互斥体:
mu := sync.Mutex{} mu.Lock() mu.Lock()
诱导结局:退出Goroutine
如果目标是提供终止手段,那么引入退出通道是一种可行的方法。在主 goroutine 中,代码可以无限期地等待来自该通道的信号。当时机成熟时,可以关闭退出通道:
var quit = make(chan struct{}) func main() { // Startup code... // Block until the quit signal arrives: <-quit } // In a separate goroutine, when termination is requested: close(quit)
注意:关闭退出通道可以触发程序立即终止,根据Go程序执行规范。
非阻塞睡眠
在阻塞主线程的情况下goroutine 是不可取的,另一种选择是使用具有较长持续时间的 time.Sleep() 。允许的最长持续时间约为 292 年:
time.Sleep(time.Duration(1<<63 - 1))
对于注定要超过此持续时间的程序,可以实现无限循环:
for { time.Sleep(time.Duration(1<<63 - 1)) }
以上是我的 Go Main Goroutine 应该永远休眠还是优雅退出?的详细内容。更多信息请关注PHP中文网其他相关文章!