返回顶部
首页 > 资讯 > 后端开发 > GO >几个小技巧帮你实现Golang永久阻塞
  • 642
分享到

几个小技巧帮你实现Golang永久阻塞

2024-04-02 19:04:59 642人浏览 泡泡鱼
摘要

目录使用 sync.WaitGroup空 select死循环用 sync.Mutexos.Signal空 channel 或者 nil channel总结参考Go 的运行时的当前设计

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()
}

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 了。

参考

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

到此这篇关于几个小技巧帮你实现golang永久阻塞的文章就介绍到这了,更多相关Golang永久阻塞内容请搜索编程网以前的文章或继续浏览下面的相关文章希望大家以后多多支持编程网!

您可能感兴趣的文档:

--结束END--

本文标题: 几个小技巧帮你实现Golang永久阻塞

本文链接: https://lsjlt.com/news/159398.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作