登录
首页 >  Golang >  Go问答

并发问题疑问

来源:SegmentFault

时间:2023-01-28 20:11:24 261浏览 收藏

在Golang实战开发的过程中,我们经常会遇到一些这样那样的问题,然后要卡好半天,等问题解决了才发现原来一些细节知识点还是没有掌握好。今天golang学习网就整理分享《并发问题疑问》,聊聊并发、go,希望可以帮助到正在努力赚钱的你。

问题内容

既然并发问题会带来的问题是:原子性破坏,可见性破坏,以及有序性不确定带来的问题。但是我恰好有多个携程对一个全局变量并发写,但是我对读到谁不敏感, 例如:

var a int64
go func() {
    // 若干操作
    a = 2
}

go func() {} {
    // 若干计算
    a = 3
}

这个例子我读取到2, 或者3都ok, 因为两个协程都是计算,无非谁先计算出来而已。

那么这种场景下,是不是就不需要考虑对a加锁?

正确答案

不加锁可以用 sync.atomic

完全没有同步机制是不行的。

golang spec 没有对原子性做任何假设,所以理论上你可能读到 0 (初始值), 2, 3 以外的值。

文中关于golang的知识介绍,希望对你的学习有所帮助!若是受益匪浅,那就动动鼠标收藏这篇《并发问题疑问》文章吧,也可关注golang学习网公众号了解相关技术文章。

声明:本文转载于:SegmentFault 如有侵犯,请联系study_golang@163.com删除
相关阅读
更多>
最新阅读
更多>
课程推荐
更多>
评论列表