欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Go語言并發(fā)之原子操作詳解

 更新時間:2022年12月29日 09:11:56   作者:機(jī)智的程序員小熊  
代碼中的加鎖操作因為涉及內(nèi)核態(tài)的上下文切換會比較耗時、代價比較高。針對基本數(shù)據(jù)類型我們還可以使用原子操作來保證并發(fā)安全,本文就來和大家詳細(xì)聊聊,需要的可以參考下

代碼中的加鎖操作因為涉及內(nèi)核態(tài)的上下文切換會比較耗時、代價比較高。針對基本數(shù)據(jù)類型我們還可以使用原子操作來保證并發(fā)安全,因為原子操作是Go語言提供的方法它在用戶態(tài)就可以完成,因此性能比加鎖操作更好。Go語言中原子操作由內(nèi)置的標(biāo)準(zhǔn)庫sync/atomic 提供。

大多數(shù)情況下我們都是針對基本數(shù)據(jù)類型進(jìn)行數(shù)據(jù)操作,能不加鎖就不加鎖。

首先很多人都不相信基本類型并發(fā)修改會出現(xiàn)競態(tài)問題。不妨嘗試一下,并發(fā)加一。

var wg sync.WaitGroup
for i := 0; i < 10000; i++ {
wg.Add(1)
go func () {
defer wg.Done()
xInt32++
}()
}
wg.Wait()
print(xInt32)

無論輸出多少次都無法達(dá)到10000,之所以如此就是因為此處的加1操作并不是原子的,都是先取當(dāng)前值,加1,再賦值,會出現(xiàn)覆蓋的情況。

修改

修改是最常用到的。

func modify(delta int32) {
atomic.AddInt32(&xInt32, delta)
atomic.AddInt64(&xInt64, int64(delta))
atomic.AddUint32(&xuInt32, uint32(delta))
atomic.AddUint64(&xuInt64, uint64(delta))
}

我們忽略了Uintptr的討論,這是內(nèi)存地址的整數(shù)表示,是用來存地址內(nèi)容的,暫時沒有遇到過指針的數(shù)據(jù)計算。

var wg sync.WaitGroup
for i := 0; i < 10000; i++ {
wg.Add(1)
go func () {
defer wg.Done()
//xInt32++
modify(1)
}()
}
wg.Wait()
print(xInt32)

改為原子操作后,發(fā)現(xiàn)每次運(yùn)行都可以得到預(yù)期的結(jié)果10000,

賦值與讀取

在并發(fā)情況下,讀取到某個變量后,在使用時變量內(nèi)容可能會被篡改,所以使用原子讀取。 在并發(fā)情況下,為某個變量賦值的時候,必須要防止讀取到寫入一半的錯誤值,所以要用原子寫入。

var xInt32 int32
atomic.StoreInt32(&xInt32, 100)
println(xInt32)
v := atomic.LoadInt32(&xInt32)
println(v)

輸出

100
100

就目前而言,原子讀寫都是為了防止讀寫一半導(dǎo)致數(shù)據(jù)錯誤,但我無法復(fù)現(xiàn)這種錯誤的場景,假如你可以復(fù)現(xiàn)請在本文底部放留言。

var v atomic.Value
v.Store([]int{})
fmt.Println(v.Load().([]int))

也可以存儲其他任意類型,但如果使用到類似append擴(kuò)容原變量的語句,而不是使用直接替換的話,原子操作也是會失效的。

比較并交換

以下是節(jié)選自《Go并發(fā)編程實戰(zhàn)》一書中的例子,比較并交換(Compare And Swap)簡稱CAS,是樂觀鎖的核心思想,所以簡單介紹一下。

var xInt32 int32
for {
    v := atomic.LoadInt32(&xInt32)
    if atomic.CompareAndSwapInt32(&xInt32, v, v+100) {
        break
    }
}
print(xInt32)
  • 這里一種無鎖的結(jié)構(gòu),是一種思路,在需要改變數(shù)據(jù)的時候,反復(fù)判斷數(shù)據(jù)是否和原數(shù)據(jù)一致
  • 一致時替換,不一致時說明被它處修改,則跳過
  • 在不創(chuàng)建互斥量和不形成臨界區(qū)的情況下,完成并發(fā)安全的值替換操作。

小結(jié)

1.最常用原子操作中的修改、基本類型的值賦值,其他不常用

2.在其他類型出現(xiàn)并發(fā)的時候盡可能使用sync包提供的并發(fā)安全的類型,下一節(jié)講。

3.通過通信共享內(nèi)存;不要通過共享內(nèi)存進(jìn)行通信。盡量使用通道。

到此這篇關(guān)于Go語言并發(fā)之原子操作詳解的文章就介紹到這了,更多相關(guān)Go語言原子操作內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • goroutine?泄漏和避免泄漏實戰(zhàn)示例

    goroutine?泄漏和避免泄漏實戰(zhàn)示例

    這篇文章主要為大家介紹了goroutine?泄漏和避免泄漏實戰(zhàn)示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • go語言csrf庫使用實現(xiàn)原理示例解析

    go語言csrf庫使用實現(xiàn)原理示例解析

    這篇文章主要為大家介紹了go語言csrf庫使用實現(xiàn)原理示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • 一文帶你玩轉(zhuǎn)Golang Prometheus Eexporter開發(fā)

    一文帶你玩轉(zhuǎn)Golang Prometheus Eexporter開發(fā)

    本文分兩大塊,一是搞清楚prometheus四種類型的指標(biāo)Counter,Gauge,Histogram,Summary用golang語言如何構(gòu)造這4種類型對應(yīng)的指標(biāo),二是搞清楚修改指標(biāo)值的場景和方式,感興趣的可以了解一下
    2023-02-02
  • Golang?pprof監(jiān)控之cpu占用率統(tǒng)計原理詳解

    Golang?pprof監(jiān)控之cpu占用率統(tǒng)計原理詳解

    經(jīng)過前面的幾節(jié)對pprof的介紹,對pprof統(tǒng)計的原理算是掌握了七八十了,但唯獨(dú)還沒有分析pprof?工具是如何統(tǒng)計cpu使用情況的,今天我們來分析下這部分
    2023-04-04
  • Go 中閉包的底層原理

    Go 中閉包的底層原理

    這篇文章主要介紹了Go 中閉包的底層原理,閉包的基本原理是一種現(xiàn)象,一個函數(shù)內(nèi)引用了外部的局部變量的現(xiàn)象,帶著些許的了解和小編一起進(jìn)入文章正題學(xué)習(xí)
    2021-10-10
  • Go語言使用AES加密解密的示例代碼

    Go語言使用AES加密解密的示例代碼

    這篇文章主要介紹了Go語言使用AES加密解密的示例代碼,本文給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友可以參考下
    2023-09-09
  • go語言的變量定義示例詳解

    go語言的變量定義示例詳解

    這篇文章主要為大家介紹了go語言的變量定義示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-12-12
  • 使用Go語言開發(fā)短鏈接服務(wù)的方法

    使用Go語言開發(fā)短鏈接服務(wù)的方法

    短鏈接一般是通過映射關(guān)系,將長長的一串網(wǎng)址,映射到幾個字符的短鏈接上,建立好這種映射關(guān)系之后保存到數(shù)據(jù)庫里,用戶每次訪問短鏈接的時候,這篇文章主要介紹了使用Go語言開發(fā)一個短鏈接服務(wù),需要的朋友可以參考下
    2024-03-03
  • Go構(gòu)建高性能的命令行工具使例詳解

    Go構(gòu)建高性能的命令行工具使例詳解

    這篇文章主要為大家介紹了Go構(gòu)建高性能的命令行工具使例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-12-12
  • go解析YAML文件(多文檔解析)

    go解析YAML文件(多文檔解析)

    本文介紹了如何使用GO語言和client-go庫處理YAML文件,特別是在Kubernetes環(huán)境下,分析了YAML的特點(diǎn),如簡潔性、易讀性、可嵌套性等,并展示了相關(guān)代碼實現(xiàn),包括單文檔和多文檔的處理方法,感興趣的可以了解一下
    2024-10-10

最新評論