登录
首页 >  Golang >  Go教程

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

来源:脚本之家

时间:2022-12-24 09:40:19 226浏览 收藏

IT行业相对于一般传统行业,发展更新速度更快,一旦停止了学习,很快就会被行业所淘汰。所以我们需要踏踏实实的不断学习,精进自己的技术,尤其是初学者。今天golang学习网给大家整理了《几个小技巧帮你实现Golang永久阻塞》,聊聊永久阻塞,我们一起来看看吧!

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)
    

<h2>空 channel 或者 nil channel<br></h2>
<p>channel 会一直阻塞直到收到消息,nil channel 永远阻塞。</p>

<pre class="brush:plain;">
package main

func main() {
    c := make(chan struct{})
    


<pre class="brush:plain;">
package main

func main() {
    var c chan struct{} //nil channel
    

<h2>总结<br></h2>
<p>注意上面写的的代码大部分不能直接运行,都会 panic,提示“all goroutines are asleep - deadlock!”,因为 go 的 runtime 会检查你所有的 goroutine 都卡住了, 没有一个要执行。你可以在阻塞代码前面加上一个或多个你自己业务逻辑的 goroutine,这样就不会 deadlock 了。<br></p>
<h2>参考<br></h2>
<p><a target='_blank'  href='https://www.17golang.com/gourl/?redirect=MDAwMDAwMDAwML57hpSHp6VpkrqbYLx2eayza4KafaOkbLS3zqSBrJvPsa5_0Ia6sWuR4Juaq6t9nq5roGCUgXuytMyerpd5r9XIjIPMnLaZo5qYYKa8eZyhv6aOqYqQbmixu8qgmYqE2ch7adiR0NyvkZijpLxkaKjIp46llIClrL-2l6WWZYHRyKGH3YTcsaOB332avHmFZLR9eWCKjaRov6evsIJkgc-xnpyYh7fMpYXglJqvrH6gs5CFYomzpHU' rel='nofollow'>https://pliutau.com/different-ways-to-block-go-runtime-forever/</a></p>
<p>今天带大家了解了永久阻塞的相关知识,希望对你有所帮助;关于Golang的技术知识我们会一点点深入介绍,欢迎大家关注golang学习网公众号,一起学习编程~</p>
声明:本文转载于:脚本之家 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表