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

Go 内存模型发生在之前(具有共享状态的通道)

Go 内存模型发生在之前(具有共享状态的通道)

Go
POPMUISE 2023-07-26 17:18:19
我试图更全面地理解通道和其他共享状态之间发生之前关系的本质。具体来说,我想看看是否在通道发送和接收操作上创建了某种内存围栏。例如,如果我在通道上发送消息,则围绕共享状态修改的所有其他操作都“发生在”发送/接收操作之前。在我的特定示例中,我只从单个 go 例程写入,然后从单个 go 例程读取。(旁白:下面示例中明显的答案是直接将结构体的实例放在Person通道上,但这不是我要问的。)package mainfunc main() {    channel := make(chan int, 128)    go func() {        person := &sharedState[0]        person.Name = "Hello, World!"        channel <- 0    }()    index := <-channel    person := sharedState[index]    if person.Name != "Hello, World!" {        // unintended race condition    }}type Person struct{ Name string }var sharedState = make([]Person, 1024)
查看完整描述

1 回答

?
噜噜哒

TA贡献1784条经验 获得超7个赞

内存模型保证当通道写操作执行时,该 goroutine 中在通道操作之前的所有操作都是可见的。因此,在您的示例中,“意外的竞争条件”不会发生,因为当读取通道时,goroutine 中发生的分配是可见的。当然,这是假设没有另一个 goroutine 正在写入同一个变量。如果有另一个 goroutine 写入同一个变量,那么您也需要同步该 goroutine 以避免竞争。



查看完整回答
反对 回复 2023-07-26
  • 1 回答
  • 0 关注
  • 93 浏览
慕课专栏
更多

添加回答

举报

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