为了账号安全,请及时绑定邮箱和手机立即绑定

在 goroutine 之间发布共享数组

在 goroutine 之间发布共享数组

Go
慕雪6442864 2022-12-13 10:23:40
我正在尝试解决这个 golang 练习https://github.com/loong/go-concurrency-exercises/tree/master/1-producer-consumer。我想我已经接近解决方案了,但是我遇到了死锁错误davecheney      tweets about golangbeertocode      does not tweet about golangironzeb         tweets about golangbeertocode      tweets about golangvampirewalk666  tweets about golangfatal error: all goroutines are asleep - deadlock!这是我的代码func producer(stream Stream) (tweets []*Tweet) {    for {        tweet, err := stream.Next()        if err == ErrEOF {            return tweets        }        tweets = append(tweets, tweet)    }}func consumer(tweets []*Tweet) {    for _, t := range tweets {            if t.IsTalkingAboutGo() {            fmt.Println(t.Username, "\ttweets about golang")        } else {            fmt.Println(t.Username, "\tdoes not tweet about golang")        }    }}func main() {    start := time.Now()    stream := GetMockStream()    data := make(chan []*Tweet)    var wg sync.WaitGroup    wg.Add(3)    // Producer    go func() {        tweets := producer(stream)        data <- tweets    }()    // Consumer    go func() {        defer wg.Done()        tweets := <-data        consumer(tweets)    }()    wg.Wait()    fmt.Printf("Process took %s\n", time.Since(start))}你的解决方案在哪里失败?
查看完整描述

1 回答

?
SMILET

TA贡献1796条经验 获得超4个赞

发生死锁是因为你传递3wg.Add(3),这意味着创建 3 个等待组,但你只需要 1 个。

解决方案是wg.Add(3)wg.Add(1).

在这里查看我的演示代码


查看完整回答
反对 回复 2022-12-13
  • 1 回答
  • 0 关注
  • 62 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信