dqwh1209 2014-10-24 06:08
浏览 72

当您向通道发送一条消息并关闭它时,是否存在数据争用?

I encountered a data race , like this

WARNING: DATA RACE
11652 Read by goroutine 14:
11653   runtime.chansend()
11654       /usr/local/go/src/pkg/runtime/chan.c:155 +0x0
            ...
11657
11658 Previous write by goroutine 13:
11659   runtime.closechan()
11660       /usr/local/go/src/pkg/runtime/chan.c:1232 +0x0
            ...

The channel has a lock, why is there a data race?

  • 写回答

1条回答 默认 最新

  • dongshi7433 2014-10-24 06:29
    关注

    A channel is being written to after it has been closed. Even if there were just a single goroutine, you'd see a panic.

    package main
    
    func main() {
        c := make(chan struct{})
        close(c)
        c <- struct{}{}  // should panic!
    }
    

    What you've got is a variety of this, but with one goroutine closing, and the other goroutine is trying to write afterwards. The race detector is properly reporting this as a data race.

    Why is the channel being closed in your program?

    评论

报告相同问题?

悬赏问题

  • ¥15 有了解d3和topogram.js库的吗?有偿请教
  • ¥100 任意维数的K均值聚类
  • ¥15 stamps做sbas-insar,时序沉降图怎么画
  • ¥15 unity第一人称射击小游戏,有demo,在原脚本的基础上进行修改以达到要求
  • ¥15 买了个传感器,根据商家发的代码和步骤使用但是代码报错了不会改,有没有人可以看看
  • ¥15 关于#Java#的问题,如何解决?
  • ¥15 加热介质是液体,换热器壳侧导热系数和总的导热系数怎么算
  • ¥100 嵌入式系统基于PIC16F882和热敏电阻的数字温度计
  • ¥15 cmd cl 0x000007b
  • ¥20 BAPI_PR_CHANGE how to add account assignment information for service line