分享
  1. 首页
  2. 文章

Golang中你不可不知的各种永远阻塞的写法

大糊涂 · · 3251 次点击 · · 开始浏览
这是一个创建于 的文章,其中的信息可能已经有所发展或是发生改变。

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

使用sync.WaitGroup

一直等待直到WaitGroup等于0

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

空select

select{}是一个没有任何case的select,它会一直阻塞

package main
func main() {
 select{}
}

死循环

虽然能阻塞,但会100%占用一个cpu。不建议使用

package main
func main() {
 for {}
}

用sync.Mutex

一个已经锁了的锁,再锁一次会一直阻塞,这个不建议使用

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

os.Signal

系统信号量,在go里面也是个channel,在收到特定的消息之前一直阻塞

package main
import (
 "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 main
func main() {
 c := make(chan struct{})
 <-c
}
package main
func main() {
 var c chan struct{} //nil channel
 <-c
}

总结

注意上面写的的代码大部分不能直接运行,都会panic,提示"all goroutines are asleep - deadlock!",因为go的runtime会检查你所有的goroutine都卡住了, 没有一个要执行。你可以在阻塞代码前面加上一个或多个你自己业务逻辑的goroutine,这样就不会deadlock了。

参考

http://pliutau.com/different-ways-to-block-go-runtime-forever/


有疑问加站长微信联系(非本文作者)

本文来自:开源中国博客

感谢作者:大糊涂

查看原文:Golang中你不可不知的各种永远阻塞的写法

入群交流(和以上内容无关):加入Go大咖交流群,或添加微信:liuxiaoyan-s 备注:入群;或加QQ群:692541889

关注微信
3251 次点击
暂无回复
添加一条新回复 (您需要 后才能回复 没有账号 ?)
  • 请尽量让自己的回复能够对别人有帮助
  • 支持 Markdown 格式, **粗体**、~~删除线~~、`单行代码`
  • 支持 @ 本站用户;支持表情(输入 : 提示),见 Emoji cheat sheet
  • 图片支持拖拽、截图粘贴等方式上传

用户登录

没有账号?注册
(追記) (追記ここまで)

今日阅读排行

    加载中
(追記) (追記ここまで)

一周阅读排行

    加载中

关注我

  • 扫码关注领全套学习资料 关注微信公众号
  • 加入 QQ 群:
    • 192706294(已满)
    • 731990104(已满)
    • 798786647(已满)
    • 729884609(已满)
    • 977810755(已满)
    • 815126783(已满)
    • 812540095(已满)
    • 1006366459(已满)
    • 692541889

  • 关注微信公众号
  • 加入微信群:liuxiaoyan-s,备注入群
  • 也欢迎加入知识星球 Go粉丝们(免费)

给该专栏投稿 写篇新文章

每篇文章有总共有 5 次投稿机会

收入到我管理的专栏 新建专栏