duanjiao6730 2016-12-22 06:55
浏览 418
已采纳

Golang:当只有一名作者使用atomic.StoreInt32更改值时,是否需要在多个读取器中使用atomic.LoadInt32?

As the title says. basically what I'm wondering is that will the atomic.StoreInt32 also lock read operation while it's writing?

Another relative question:, is atomic.StoreUint64(&procRate, procCount) equivalent to atomic.StoreUint64(&procRate, atomic.LoadUint64(&procCount))?

Thanks in advance.

  • 写回答

1条回答 默认 最新

  • dsd30433 2016-12-22 15:19
    关注

    Yes, you need to use atomic operations when you are both loading and storing the same value. The race detector should warn you about this.

    As for the second question, if the procCount value is also being used concurrently, then you still need to load it using an atomic operation. These two are not equivalent:

    atomic.StoreUint64(&procRate, procCount)
    atomic.StoreUint64(&procRate, atomic.LoadUint64(&procCount))
    

    The former reads procCount directly to pass to StoreUint64, while the latter passes a copy safely obtained via LoadUint64.

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论

报告相同问题?

悬赏问题

  • ¥15 已知曲线满足正余弦函数,根据其峰值,还原出整条曲线
  • ¥20 无法创建新的堆栈防护界面
  • ¥15 sessionStorage在vue中的用法
  • ¥15 wordpress更换域名后用户图片头像不显示
  • ¥15 如何在ubunto上安装CEF (Chromium Embedded Framework),并且基于qt实现打开一个web
  • ¥30 AD9854 为什么输出波形幅度受限,AI机器人勿扰
  • ¥15 如何在ubunto上安装CEF (Chromium Embedded Framework
  • ¥15 如何联系真正的开发者而非公司
  • ¥15 有偿求苍穹外卖环境配置
  • ¥15 代码在keil5里变成了这样怎么办啊,文件图像也变了,