一个已经锁了的锁,再锁一次会一直阻塞,这个不建议使用
packagemain
import"sync"
funcmain{
varm sync.Mutex
m.Lock
}
os.Signal
系统信号量,在 go 里面也是个 channel,在收到特定的消息之前一直阻塞
packagemain
import(
"os"
"syscall"
"os/signal"
)
funcmain{
sig := make( chanos.Signal, 2)
signal.Notify(sig, syscall.SIGTERM, syscall.SIGINT)
<-sig
}
空 channel 或者 nil channel
channel 会一直阻塞直到收到消息,nil channel 永远阻塞。
packagemain
funcmain{
c := make( chanstruct{})
<-c
}
复制代码
packagemain
funcmain{
varc chanstruct{} //nil channel
<-c
}
总结
注意上面写的的代码大部分不能直接运行,都会 panic,提示“all goroutines are asleep - deadlock!”,因为 go 的 runtime 会检查你所有的 goroutine 都卡住了, 没有一个要执行。你可以在阻塞代码前面加上一个或多个你自己业务逻辑的 goroutine,这样就不会 deadlock 了。
- EOF -
点击标题可跳转
1、 B 站高可用架构实践
2、 Go 实现 Nginx 加权轮询算法
3、 Golang 百万级并发 Server
看完本文有收获?请分享给更多人
推荐关注「Linux 爱好者」,提升Linux技能