当前位置:首页 > 科技  > 软件

用Golang做一个永久阻塞,有哪些小技巧 ?

来源: 责编: 时间:2024-05-07 09:13:08 82观看
导读Go 的运行时的当前设计,假定程序员自己负责检测何时终止一个 goroutine 以及何时终止该程序。可以通过调用 os.Exit 或从 main() 函数的返回来以正常方式终止程序。而有时候我们需要的是使程序阻塞在这一行。使用 sync

Go 的运行时的当前设计,假定程序员自己负责检测何时终止一个 goroutine 以及何时终止该程序。可以通过调用 os.Exit 或从 main() 函数的返回来以正常方式终止程序。而有时候我们需要的是使程序阻塞在这一行。H4b28资讯网——每日最新资讯28at.com

使用 sync.WaitGroup一直等待直到 WaitGroup 等于 0H4b28资讯网——每日最新资讯28at.com

package mainimport "sync"func main() {    var wg sync.WaitGroup    wg.Add(1)    wg.Wait()}

空 selectselect{}是一个没有任何 case 的 select,它会一直阻塞H4b28资讯网——每日最新资讯28at.com

package mainfunc main() {    select{}}

》》》》程序员福利《《《《H4b28资讯网——每日最新资讯28at.com

H4b28资讯网——每日最新资讯28at.com

微店买买,,,H4b28资讯网——每日最新资讯28at.com

Goland正版激活码,获取后直接激活即可H4b28资讯网——每日最新资讯28at.com

H4b28资讯网——每日最新资讯28at.com

死循环虽然能阻塞,但会 100%占用一个 cpu。不建议使用H4b28资讯网——每日最新资讯28at.com

package mainfunc main() {    for {}}

用 sync.Mutex一个已经锁了的锁,再锁一次会一直阻塞,这个不建议使用H4b28资讯网——每日最新资讯28at.com

package mainimport "sync"func main() {    var m sync.Mutex    m.Lock()}

os.Signal系统信号量,在 go 里面也是个 channel,在收到特定的消息之前一直阻塞H4b28资讯网——每日最新资讯28at.com

package mainimport (    "os"    "syscall"    "os/signal")func main() {    sig := make(chan os.Signal, 2)    signal.Notify(sig, syscall.SIGTERM, syscall.SIGINT)    <-sig}

空 channel 或者 nil channelchannel 会一直阻塞直到收到消息,nil channel 永远阻塞。H4b28资讯网——每日最新资讯28at.com

package mainfunc main() {    c := make(chan struct{})    <-c}package mainfunc main() {    var c chan struct{} //nil channel    <-c}

总结

注意上面写的的代码大部分不能直接运行,都会 panic,提示“all goroutines are asleep - deadlock!”,因为 go 的 runtime 会检查你所有的 goroutine 都卡住了, 没有一个要执行。H4b28资讯网——每日最新资讯28at.com

本文链接://www.dmpip.com//www.dmpip.com/showinfo-26-87014-0.html用Golang做一个永久阻塞,有哪些小技巧 ?

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: Web Components 取代 Vue?我觉得不太行!

下一篇: 前端监控各指标含义 ?怎么监控怎么优化

标签:
  • 热门焦点
Top
Baidu
map