亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

golang atomic原子操作示例詳解

 更新時(shí)間:2023年09月27日 08:53:19   作者:lincoln_hlf1  
這篇文章主要為大家介紹了golang atomic原子操作示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

sync/atomic 介紹

當(dāng)我們想要對(duì)某個(gè)變量并發(fā)安全的修改,除了使用官方提供的 mutex,還可以使用 sync/atomic 包的原子操作,它能夠保證對(duì)變量的讀取或修改期間不被其他的協(xié)程所影響。

atomic 包的原子操作是通過(guò) CPU 指令,也就是在硬件層次去實(shí)現(xiàn)的,性能較好,不需要像 mutex 那樣記錄很多狀態(tài)。 當(dāng)然,mutex 不止是對(duì)變量的并發(fā)控制,更多的是對(duì)代碼塊的并發(fā)控制,2 者側(cè)重點(diǎn)不一樣。

sync/atomic 操作

atomic 包有幾種原子操作,主要是 Add、CompareAndSwap、Load、Store、Swap。

Add

atomic 的 Add 是針對(duì) int 和 uint 進(jìn)行原子加值的:

func AddInt32(addr *int32, delta int32) (new int32)
func AddUint32(addr *uint32, delta uint32) (new uint32)
func AddInt64(addr *int64, delta int64) (new int64)
func AddUint64(addr *uint64, delta uint64) (new uint64)
func AddUintptr(addr *uintptr, delta uintptr) (new uintptr)

CompareAndSwap

比較并交換方法實(shí)現(xiàn)了類似樂(lè)觀鎖的功能,只有原來(lái)的值和傳入的 old 值一樣,才會(huì)去修改:

func CompareAndSwapInt32(addr *int32, old, new int32) (swapped bool)
func CompareAndSwapInt64(addr *int64, old, new int64) (swapped bool)
func CompareAndSwapUint32(addr *uint32, old, new uint32) (swapped bool)
func CompareAndSwapUint64(addr *uint64, old, new uint64) (swapped bool)
func CompareAndSwapUintptr(addr *uintptr, old, new uintptr) (swapped bool)
func CompareAndSwapPointer(addr *unsafe.Pointer, old, new unsafe.Pointer) (swapped bool)

需要注意的是,CompareAndSwap 有可能產(chǎn)生 ABA 現(xiàn)象發(fā)生。也就是原來(lái)的值是 A,后面被修改 B,再后面修改為 A。在這種情況下也符合了 CompareAndSwap 規(guī)則,即使中途有被改動(dòng)過(guò)。

Load

Load 方法是為了防止在讀取過(guò)程中,有其他協(xié)程發(fā)起修改動(dòng)作,影響了讀取結(jié)果,常用于配置項(xiàng)的整個(gè)讀取。

func LoadInt32(addr *int32) (val int32)
func LoadInt64(addr *int64) (val int64)
func LoadUint32(addr *uint32) (val uint32)
func LoadUint64(addr *uint64) (val uint64)
func LoadUintptr(addr *uintptr) (val uintptr)
func LoadPointer(addr *unsafe.Pointer) (val unsafe.Pointer)

Store

有原子讀取,就有原子修改值,前面提到過(guò)的 Add 只適用于 int、uint 類型的增減,并沒(méi)有其他類型的修改,而 Sotre 方法通過(guò) unsafe.Pointer 指針原子修改,來(lái)達(dá)到了對(duì)其他類型的修改。

func StoreInt32(addr *int32, val int32)
func StoreInt64(addr *int64, val int64)
func StoreUint32(addr *uint32, val uint32)
func StoreUint64(addr *uint64, val uint64)
func StoreUintptr(addr *uintptr, val uintptr)
func StorePointer(addr *unsafe.Pointer, val unsafe.Pointer)

Swap

Swap 方法實(shí)現(xiàn)了對(duì)值的原子交換,不僅 int,uint 可以交換,指針也可以。

func SwapInt32(addr *int32, new int32) (old int32)
func SwapInt64(addr *int64, new int64) (old int64)
func SwapUint32(addr *uint32, new uint32) (old uint32)
func SwapUint64(addr *uint64, new uint64) (old uint64)
func SwapUintptr(addr *uintptr, new uintptr) (old uintptr)
func SwapPointer(addr *unsafe.Pointer, new unsafe.Pointer) (old unsafe.Pointer)

總結(jié)

atomic 很多時(shí)候可能都沒(méi)有使用上,畢竟 mutex 的拓展性比較好,使用起來(lái)也比較友好。但這并不妨礙我們對(duì)極致性能的追求,有時(shí)候,細(xì)節(jié)決定了性能!

以上就是golang atomic原子操作示例詳解的詳細(xì)內(nèi)容,更多關(guān)于golang atomic原子操作的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • 淺談go-restful框架的使用和實(shí)現(xiàn)

    淺談go-restful框架的使用和實(shí)現(xiàn)

    這篇文章主要介紹了淺談go-restful框架的使用和實(shí)現(xiàn),小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧
    2018-03-03
  • Golang反射獲取結(jié)構(gòu)體的值和修改值的代碼示例

    Golang反射獲取結(jié)構(gòu)體的值和修改值的代碼示例

    這篇文章主要給大家介紹了golang反射獲取結(jié)構(gòu)體的值和修改值的代碼示例及演示效果,對(duì)我們的學(xué)習(xí)或工作有一定的幫助,感興趣的同學(xué)可以參考閱讀本文
    2023-08-08
  • Go語(yǔ)言基于HTTP的內(nèi)存緩存服務(wù)的實(shí)現(xiàn)

    Go語(yǔ)言基于HTTP的內(nèi)存緩存服務(wù)的實(shí)現(xiàn)

    這篇文章主要介紹了Go語(yǔ)言基于HTTP的內(nèi)存緩存服務(wù),本程序采用REST接口,支持設(shè)置(Set)、獲取(Get)和刪除(Del)這3個(gè)基本操作,同時(shí)還支持對(duì)緩存服務(wù)狀態(tài)進(jìn)行查詢,需要的朋友可以參考下
    2022-08-08
  • go 壓縮解壓zip文件源碼示例

    go 壓縮解壓zip文件源碼示例

    這篇文章主要為大家介紹了go壓縮及解壓zip文件的源碼示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-07-07
  • Go使用Redis實(shí)現(xiàn)分布式鎖的常見方法

    Go使用Redis實(shí)現(xiàn)分布式鎖的常見方法

    Redis?提供了一些原語(yǔ),可以幫助我們實(shí)現(xiàn)高效的分布式鎖,下邊是使用?Redis?實(shí)現(xiàn)分布式鎖的一種常見方法,通過(guò)代碼示例給大家介紹的非常詳細(xì),具有一定的參考價(jià)值,需要的朋友可以參考下
    2024-11-11
  • go mod 使用舊版本 版本號(hào)指定方式

    go mod 使用舊版本 版本號(hào)指定方式

    這篇文章主要介紹了go mod 使用舊版本 版本號(hào)指定方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。一起跟隨小編過(guò)來(lái)看看吧
    2021-05-05
  • Go語(yǔ)言接口定義與用法示例

    Go語(yǔ)言接口定義與用法示例

    這篇文章主要介紹了Go語(yǔ)言接口定義與用法,較為詳細(xì)的分析了Go語(yǔ)言中接口的概念、定義、用法,需要的朋友可以參考下
    2016-07-07
  • Golang語(yǔ)言JSON解碼函數(shù)Unmarshal的使用

    Golang語(yǔ)言JSON解碼函數(shù)Unmarshal的使用

    本文主要介紹了Golang語(yǔ)言JSON解碼函數(shù)Unmarshal的使用,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-01-01
  • Golang sync.Pool的源碼解析

    Golang sync.Pool的源碼解析

    Pool是用于存放臨時(shí)對(duì)象的集合,這些對(duì)象是為了后續(xù)的使用,以達(dá)到復(fù)用對(duì)象的效果,本文將詳解解析sync.Pool 源碼,需要的朋友可以參考下
    2023-05-05
  • 關(guān)于go-micro與其它gRPC框架之間的通信問(wèn)題及解決方法

    關(guān)于go-micro與其它gRPC框架之間的通信問(wèn)題及解決方法

    在之前的文章中分別介紹了使用gRPC官方插件和go-micro插件開發(fā)gRPC應(yīng)用程序的方式,都能正常走通。不過(guò)當(dāng)兩者混合使用的時(shí)候,互相訪問(wèn)就成了問(wèn)題,下面通過(guò)本文給大家講解下go-micro與gRPC框架通信問(wèn)題,一起看看吧
    2022-04-04

最新評(píng)論