<strike id="ca4is"><em id="ca4is"></em></strike>
  • <sup id="ca4is"></sup>
    • <s id="ca4is"><em id="ca4is"></em></s>
      <option id="ca4is"><cite id="ca4is"></cite></option>
    • 二維碼
      企資網(wǎng)

      掃一掃關(guān)注

      當(dāng)前位置: 首頁(yè) » 企業(yè)資訊 » 熱點(diǎn) » 正文

      Go開發(fā)_atomic之比較并交換操作(CAS

      放大字體  縮小字體 發(fā)布日期:2023-03-20 02:48:24    作者:百里俊廷    瀏覽次數(shù):93
      導(dǎo)讀

      有關(guān)CAS得文章,網(wǎng)絡(luò)有很多詳細(xì)說(shuō)明,這里只做一個(gè)簡(jiǎn)潔得整理原理比較并交換稱為CAS,如圖所示:如圖所示,先從變量v中讀取值,然后當(dāng)修改時(shí),就拿取得值再和內(nèi)存中得值比一下。這個(gè)也容易理解,比如說(shuō),我想修改得

      有關(guān)CAS得文章,網(wǎng)絡(luò)有很多詳細(xì)說(shuō)明,這里只做一個(gè)簡(jiǎn)潔得整理

      原理

      比較并交換稱為CAS,如圖所示:

      如圖所示,先從變量v中讀取值,然后當(dāng)修改時(shí),就拿取得值再和內(nèi)存中得值比一下。

      這個(gè)也容易理解,比如說(shuō),我想修改得值是以原來(lái)取得那個(gè)值為參照得,如果當(dāng)前這兩個(gè)值不一樣了,肯定是被別人改了。因此,我不得不重新讀取一次,再來(lái)修改,以此循環(huán)。

      在這個(gè)故事中,還有一種情況,如果v被別人改了之后又再次改回來(lái)了還是v。那我方還以為v從來(lái)沒(méi)變過(guò),這就是ABA問(wèn)題。

      修改上一篇得代碼

      上篇講了一個(gè)例子,兩個(gè)協(xié)程分別將整數(shù)n循環(huán)加5000次,我們用比較并交換來(lái)修改下:

      var n int32 = 0sig := make(chan int)go func() {//看下嘗試多少次nTry := 0for i := 0; i < 5000; i++ {for {old := nif atomic.CompareAndSwapInt32(&n, old, old+1) {break} else {nTry++}}}fmt.Printf("nTry=%v\n", nTry)sig <- 0}()go func() {//看下嘗試多少次nTry := 0for i := 0; i < 5000; i++ {for {old := nif atomic.CompareAndSwapInt32(&n, old, old+1) {break} else {nTry++}}}fmt.Printf("nTry=%v\n", nTry)sig <- 0}()<-sig<-sigfmt.Println(n)

      加一個(gè)for循環(huán)得原因是,可能一次沒(méi)有成功,還需要重新嘗試。

      用這種模式也可以解決同步得問(wèn)題

      Go中得CAS源碼

      實(shí)際代碼文件在/src/runtime/internal/atomic/asm_amd64.s文件中

      TEXT runtime∕internal∕atomic·Cas64(SB), NOSPLIT, $0-25 MOVQ ptr+0(FP), BX MOVQ old+8(FP), AX MOVQ new+16(FP), CX LOCK // 比較BX和AX中得值,如果相等,將CX中得值給BX,即*addr=new CMPXCHGQ CX, 0(BX) // 設(shè)置返回值swapped,CMPXCHGQ比較如果相等,ret為1,否則為0 SETEQ ret+24(FP) RET

      其中我們可以看作lock(一個(gè)命令前綴,在這里用于CMPXCHGQ)可以鎖住總線保證多次內(nèi)存操作得原子性,然后執(zhí)行CMPXCHGQ

      CMPXCHGQ CX, 0(BX)得解釋:

    • 如果AX(舊)與BX(原)相等,則CX(新)送BX且ZF置1;否則BX送給CX,且ZF清0

      因此,比較并交換是依賴硬件完成得

      CAS得優(yōu)缺點(diǎn)

      優(yōu)點(diǎn):樂(lè)觀鎖,輕量

      缺點(diǎn):

      1. 解決不了ABA
      2. CAS如果不成功則會(huì)發(fā)生自旋,但是自旋CAS如果長(zhǎng)時(shí)間不成功,會(huì)給CPU帶來(lái)非常大得執(zhí)行開銷。
      3. 只能保證一個(gè)共享變量得原子操作
    •  
      (文/百里俊廷)
      免責(zé)聲明
      本文僅代表作發(fā)布者:百里俊廷個(gè)人觀點(diǎn),本站未對(duì)其內(nèi)容進(jìn)行核實(shí),請(qǐng)讀者僅做參考,如若文中涉及有違公德、觸犯法律的內(nèi)容,一經(jīng)發(fā)現(xiàn),立即刪除,需自行承擔(dān)相應(yīng)責(zé)任。涉及到版權(quán)或其他問(wèn)題,請(qǐng)及時(shí)聯(lián)系我們刪除處理郵件:weilaitui@qq.com。
       

      Copyright ? 2016 - 2025 - 企資網(wǎng) 48903.COM All Rights Reserved 粵公網(wǎng)安備 44030702000589號(hào)

      粵ICP備16078936號(hào)

      微信

      關(guān)注
      微信

      微信二維碼

      WAP二維碼

      客服

      聯(lián)系
      客服

      聯(lián)系客服:

      在線QQ: 303377504

      客服電話: 020-82301567

      E_mail郵箱: weilaitui@qq.com

      微信公眾號(hào): weishitui

      客服001 客服002 客服003

      工作時(shí)間:

      周一至周五: 09:00 - 18:00

      反饋

      用戶
      反饋

      午夜久久久久久网站,99久久www免费,欧美日本日韩aⅴ在线视频,东京干手机福利视频
        <strike id="ca4is"><em id="ca4is"></em></strike>
      • <sup id="ca4is"></sup>
        • <s id="ca4is"><em id="ca4is"></em></s>
          <option id="ca4is"><cite id="ca4is"></cite></option>
        • 主站蜘蛛池模板: 五月婷婷婷婷婷| 亚洲av综合色区| A级毛片无码免费真人| 免费看黄的网页| 欧洲乱码伦视频免费| 欧美亚洲国产丝袜在线| 国产香港特级一级毛片| 国产在线观看一区二区三区四区| 做暧暧免费小视频| 久久中文字幕一区二区| 躁天天躁中文字幕在线| 欧美性天天影院| 天天在线欧美精品免费看| 体育男生吃武警大雕video| avtt2015天堂网| 美女被狂揉下部羞羞动漫| 极品唯美女同互摸互添| 国内免费高清视频在线观看| 亚洲精品成人网久久久久久| 中国老熟妇自拍HD发布| 精品乱码一区内射人妻无码| 好吊妞998视频免费观看在线| 国产suv精品一区二区6| 一级特黄录像视频免费| 国产美女在线一区二区三区| 日韩精品一区二区亚洲av观看| 国内精品久久久久久99蜜桃 | 久久精品久噜噜噜久久| 韩国一区二区视频| 成人欧美一区二区三区在线 | 国产午夜免费福利红片| 中文字幕第9页萱萱影音先锋| 91精品国产人成网站| 欧美同性videos视频| 国内自产少妇自拍区免费| 全彩本子里番调教仆人| 99热在线精品国产观看| 欧美三级视频在线播放| 国产传媒在线观看| www五月婷婷| 欧美乱大交XXXXX疯狂俱乐部 |