首页后端开发其他后端知识用什么方法实现Golang永久阻塞呢?

用什么方法实现Golang永久阻塞呢?

时间2024-03-26 20:20:03发布访客分类其他后端知识浏览1062
导读:这篇文章主要给大家介绍“用什么方法实现Golang永久阻塞呢?”的相关知识,下文通过实际案例向大家展示操作过程,内容简单清晰,易于学习,有这方面学习需要的朋友可以参考,希望这篇“用什么方法实现Golang永久阻塞呢?”文章能对大家有所帮助。...
这篇文章主要给大家介绍“用什么方法实现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)
    -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 了。


关于“用什么方法实现Golang永久阻塞呢?”的内容就介绍到这,感谢各位的阅读,相信大家对用什么方法实现Golang永久阻塞呢?已经有了进一步的了解。大家如果还想学习更多知识,欢迎关注网络,小编将为大家输出更多高质量的实用文章!

声明:本文内容由网友自发贡献,本站不承担相应法律责任。对本内容有异议或投诉,请联系2913721942#qq.com核实处理,我们将尽快回复您,谢谢合作!


若转载请注明出处: 用什么方法实现Golang永久阻塞呢?
本文地址: https://pptw.com/jishu/653735.html
Bootstrap信息提示框的用法是什么,触发方式是怎样 Bootstrap辅助类的相关知识有哪些

游客 回复需填写必要信息