本篇内容主要讲解“如何实现Golang永久阻塞”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何实现Golang永久阻塞”吧!
Go 的运行时的当前设计,假定程序员自己负责检测何时终止一个 goroutine 以及何时终止该程序。可以通过调用 os.Exit 或从 main() 函数的返回来以正常方式终止程序。而有时候我们需要的是使程序阻塞在这一行。
使用 sync.WaitGroup
一直等待直到 WaitGroup 等于 0
package mainimport "sync"func main() { var wg sync.WaitGroup wg.Add(1) wg.Wait()}
空 select
select{}是一个没有任何 case 的 select,它会一直阻塞
package mainfunc main() { select{}}
死循环
虽然能阻塞,但会 100%占用一个 cpu。不建议使用
package mainfunc main() { for {}}
用 sync.Mutex
一个已经锁了的锁,再锁一次会一直阻塞,这个不建议使用
package mainimport "sync"func main() { var m sync.Mutex m.Lock()}
os.Signal
系统信号量,在 go 里面也是个 channel,在收到特定的消息之前一直阻塞
package mainimport ( "os" "syscall" "os/signal")func main() { sig := make(chan os.Signal, 2) signal.Notify(sig, syscall.SIGTERM, syscall.SIGINT) <-sig}
空 channel 或者 nil channel
channel 会一直阻塞直到收到消息,nil channel 永远阻塞。
package mainfunc main() { c := make(chan struct{}) <-c}
package mainfunc main() { var c chan struct{} //nil channel <-c}
到此,相信大家对“如何实现Golang永久阻塞”有了更深的了解,不妨来实际操作一番吧!这里是编程网网站,更多相关内容可以进入相关频道进行查询,关注我们,继续学习!