Go语言死锁:Goroutine休眠导致致命错误,如何解决?

go语言死锁:goroutine休眠导致致命错误,如何解决?

goroutine 休眠导致致命错误:死锁

go语言中,如下代码段可能会出现一个 "fatal error: all goroutines are asleep - deadlock!" 的错误消息:

func main() {
    a := make(chan bool)
    b := make(chan bool)
    defer close(a)
    defer close(b)
    var wg sync.waitgroup
    wg.add(2)
    go func() {
        for i := 0; i < 10; i += 2 {
            if <-a {
                fmt.println(i)
                b <- true
            }
        }
        wg.done()
    }()
    go func() {
        for i := 1; i < 10; i += 2 {
            if <-b {
                fmt.println(i)
                a <- true
            }
        }
        wg.done()
    }()
    a <- true
    wg.wait()
}

该错误的原因是代码存在死锁。两个goroutine都在等待彼此发送通道信号,但由于没有外部goroutine来打破这个循环,程序就会永远卡在等待状态。

问题出在 b goroutine的最后一次写入 a

立即学习go语言免费学习笔记(深入)”;

为了解决这个问题,可以添加一个简单的从 a 通道读取数据的操作,如代码段中的:

    A := make(chan bool)
    B := make(chan bool)
    defer close(A)
    defer close(B)
    var wg sync.WaitGroup
    wg.Add(2)
    go func() {
        for i := 0; i < 10; i += 2 {
            if <-A {
                fmt.Println(i)
                B <- true
            }
        }
        <-A  // 新添加的行
        wg.Done()
    }()

通过添加这一行,即使在 b goroutine完成时,也会继续从 a 通道中读取数据,从而打破循环并使程序正常执行。

以上就是Go语言死锁:Goroutine休眠导致致命错误,如何解决?的详细内容,更多请关注其它相关文章!