美文网首页
Golang sync.atomic 相比 sync.Mutex

Golang sync.atomic 相比 sync.Mutex

作者: WuCh1k1n | 来源:发表于2020-02-24 15:35 被阅读0次

sync.atomic

Golang 标准库中的 sync/atomic 为开发者提供了对几种简单类型的原子操作函数。这些简单类型包括int32, int64, uint32, uint64, uintptr, unsafe.Pointer。这些原子操作函数有以下5种:增减(Add),存储(Store),载入(Load),交换(Swap),比较并交换(CompareAndSwap)。


sync.atomic 与 sync.Mutex 对比

对比实验源码:

package main

import (
    "fmt"
    "sync"
    "sync/atomic"
    "time"
)

func main() {
    test1()
    test2()
}

// sync.Mutex
func test1() {
    var wg sync.WaitGroup
    var mutex sync.Mutex
    count := int64(0)
    t := time.Now()
    for i := 0; i < 10000; i++ {
        wg.Add(1)
        go func(i int) {
            mutex.Lock()
            count++
            wg.Done()
            mutex.Unlock()
        }(i)
    }

    wg.Wait()

    fmt.Printf("test1 花费时间:%d, count的值为:%d \n", time.Now().Sub(t), count)
}

// sync.atomic
func test2() {
    var wg sync.WaitGroup
    count := int64(0)
    t := time.Now()
    for i := 0; i < 10000; i++ {
        wg.Add(1)
        go func(i int) {
            atomic.AddInt64(&count, 1)
            wg.Done()
        }(i)
    }

    wg.Wait()

    fmt.Printf("test2 花费时间:%d, count的值为:%d \n", time.Now().Sub(t), count)
}

对比实验运行结果:

test1 花费时间:4514661, count的值为:10000
test2 花费时间:3361215, count的值为:10000

test1,test2 函数分别通过 sync.Mutex 和 sync.atomic 提供的原子操作函数实现对一个 int64 整数进行 10000 次多线程安全的加法运算。通过实验运行结果可知,sync.atomic 比 sync.Mutex 的执行效率更高。

sync.atomic 的实现原理大致是向 CPU 发送对某一个块内存的 LOCK 信号,然后就将此内存块加锁,从而保证了内存块操作的原子性。这种对 CPU 发送信号对内存加锁的方式,比 sync.Mutex 这种在语言层面对内存加锁的方式更底层,因此也更高效。

除此之外,sync.atomic 避免了加锁、解锁的过程,一行代码就可以完成线程安全操作,也比 sync.Mutex 更简洁,代码可读性更强。

相关文章

  • Golang sync.atomic 相比 sync.Mutex

    sync.atomic Golang 标准库中的 sync/atomic 为开发者提供了对几种简单类型的原子操作函...

  • Go|sync.mutex 源代码分析

    sync.mutex 源代码分析 [TOC] 针对 Golang 1.10.3 的 sync.Mutex 进行分析...

  • Golang之Mutex

    引用 sync.mutex 源代码分析 Golang 中 Mutex 的源码实现 建议阅读 Golang中Mute...

  • golang之sync.Mutex互斥锁源码分析

    针对Golang 1.9的sync.Mutex进行分析,与Golang 1.10基本一样除了将panic改为了th...

  • Go 原子操作

    本文讲解 golang 中 sync.atomic 的常见操作 atomic 提供的原子操作能够确保任一时刻只有一...

  • golang sync.Mutex

     相较于Go语言宣扬的“用通讯的方式共享数据”,通过共享数据的方式来传递信息和协调线程运行的做法其实更加主流,比较...

  • golang源码阅读-sync.Mutex

    【golang源码分析】sync.Mutex 概述 Mutex只有两个阻塞方法Lock和Unlock,有两种工作模...

  • 轻松检测Golang并发的数据竞争

    Golang中我们使用Channel或者sync.Mutex等锁保护数据,有没有一种机制可以检测代码中的数据竞争呢...

  • golang 互斥锁 sync.Mutex

    一、介绍sync.Mutex为互斥锁(也叫全局锁),Lock()加锁,Unlock()解锁。 二、场景适用于场景:...

  • Golang 1.11 sync.Mutex 源码解析

    本文基于 go1.11 版本。 Mutex 使用 在深入源码之前,要先搞清楚一点,对 Golang 中互斥锁 sy...

网友评论

      本文标题:Golang sync.atomic 相比 sync.Mutex

      本文链接:https://www.haomeiwen.com/subject/rsyvqhtx.html