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

java并發(fā)編程之cas詳解

 更新時(shí)間:2017年11月03日 15:12:35   投稿:mengwei  
這篇文章主要介紹了java并發(fā)編程之cas詳解,涉及cas使用場(chǎng)景和cas用作原子操作等內(nèi)容,具有一定參考價(jià)值,需要的朋友可以了解下。

CAS(Compare and swap)比較和替換是設(shè)計(jì)并發(fā)算法時(shí)用到的一種技術(shù)。簡(jiǎn)單來說,比較和替換是使用一個(gè)期望值和一個(gè)變量的當(dāng)前值進(jìn)行比較,如果當(dāng)前變量的值與我們期望的值相等,就使用一個(gè)新值替換當(dāng)前變量的值。這聽起來可能有一點(diǎn)復(fù)雜但是實(shí)際上你理解之后發(fā)現(xiàn)很簡(jiǎn)單,接下來,讓我們跟深入的了解一下這項(xiàng)技術(shù)。

CAS的使用場(chǎng)景

在程序和算法中一個(gè)經(jīng)常出現(xiàn)的模式就是“check and act”模式。先檢查后操作模式發(fā)生在代碼中首先檢查一個(gè)變量的值,然后再基于這個(gè)值做一些操作。下面是一個(gè)簡(jiǎn)單的示例:

class MyLock {
  private boolean locked = false;
  public boolean lock() {
    if(!locked) {
      locked = true;
      return true;
    }
    return false;
  }
}

上面這段代碼,如果用在多線程的程序會(huì)出現(xiàn)很多錯(cuò)誤,不過現(xiàn)在請(qǐng)忘掉它。

如你所見,lock()方法首先檢查locked>成員變量是否等于false,如果等于,就將locked設(shè)為true。

如果同個(gè)線程訪問同一個(gè)MyLock實(shí)例,上面的lock()將不能保證正常工作。如果一個(gè)線程檢查locked的值,然后將其設(shè)置為false,與此同時(shí),一個(gè)線程B也在檢查locked的值,又或者,在線程A將locked的值設(shè)為false之前。因此,線程A和線程B可能都看到locked的值為false,然后兩者都基于這個(gè)信息做一些操作。

為了在一個(gè)多線程程序中良好的工作,”checkthenact”操作必須是原子的。原子就是說”check“操作和”act“被當(dāng)做一個(gè)原子代碼塊執(zhí)行。不存在多個(gè)線程同時(shí)執(zhí)行原子塊。

下面是一個(gè)代碼示例,把之前的lock()方法用synchronized關(guān)鍵字重構(gòu)成一個(gè)原子塊。

class MyLock {
  private boolean locked = false;
  public synchronized boolean lock() {
    if(!locked) {
      locked = true;
      return true;
    }
    return false;
  }
}

現(xiàn)在lock()方法是同步的,所以,在某一時(shí)刻只能有一個(gè)線程在同一個(gè)MyLock實(shí)例上執(zhí)行它。

原子的lock方法實(shí)際上是一個(gè)”compare and swap“的例子。

CAS用作原子操作

現(xiàn)在CPU內(nèi)部已經(jīng)執(zhí)行原子的CAS操作。Java5以來,你可以使用java.util.concurrent.atomic包中的一些原子類來使用CPU中的這些功能。

下面是一個(gè)使用AtomicBoolean類實(shí)現(xiàn)lock()方法的例子:

public static class MyLock {
  private AtomicBoolean locked = new AtomicBoolean(false);
  public boolean lock() {
    return locked.compareAndSet(false, true);
  }
}

locked變量不再是boolean類型而是AtomicBoolean。這個(gè)類中有一個(gè)compareAndSet()方法,它使用一個(gè)期望值和AtomicBoolean實(shí)例的值比較,和兩者相等,則使用一個(gè)新值替換原來的值。在這個(gè)例子中,它比較locked的值和false,如果locked的值為false,則把修改為true。

如果值被替換了,compareAndSet()返回true,否則,返回false。

使用Java5+提供的CAS特性而不是使用自己實(shí)現(xiàn)的的好處是Java5+中內(nèi)置的CAS特性可以讓你利用底層的你的程序所運(yùn)行機(jī)器的CPU的CAS特性。這會(huì)使還有CAS的代碼運(yùn)行更快。

總結(jié)

以上就是關(guān)于java并發(fā)編程之cas詳解的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站:Java系統(tǒng)的高并發(fā)解決方法詳解Java并發(fā)編程之重入鎖與讀寫鎖、Java并發(fā)編程Semaphore計(jì)數(shù)信號(hào)量詳解等,有什么問題可以隨時(shí)留言,歡迎您的寶貴意見,小編會(huì)及時(shí)回復(fù)大家的。感謝朋友們對(duì)本站的支持!

相關(guān)文章

  • 實(shí)例講解Java并發(fā)編程之閉鎖

    實(shí)例講解Java并發(fā)編程之閉鎖

    這篇文章主要介紹了實(shí)例講解Java并發(fā)編程之閉鎖,閉鎖相當(dāng)于一扇門,在閉鎖到達(dá)結(jié)束狀態(tài)之前,這扇門一直是關(guān)閉著的,沒有任何線程可以通過,當(dāng)?shù)竭_(dá)結(jié)束狀態(tài)時(shí),這扇門才會(huì)打開并容許所有線程通過,需要的朋友可以參考下
    2015-04-04
  • MyBatisPlus批量添加的優(yōu)化與報(bào)錯(cuò)解決

    MyBatisPlus批量添加的優(yōu)化與報(bào)錯(cuò)解決

    MybatisPlus是一個(gè)高效的java持久層框架,它在Mybatis的基礎(chǔ)上增加了一些便捷的功能,提供了更加易用的API,可以大幅度提高開發(fā)效率,這篇文章主要給大家介紹了關(guān)于MyBatisPlus批量添加的優(yōu)化與報(bào)錯(cuò)解決的相關(guān)資料,需要的朋友可以參考下
    2023-05-05
  • 如何用Java模擬XN*2圖靈機(jī)

    如何用Java模擬XN*2圖靈機(jī)

    這篇文章主要介紹了如何用Java模擬XN*2圖靈機(jī)方法,感興趣的朋友可以參考下
    2021-04-04
  • java實(shí)現(xiàn)注冊(cè)登錄系統(tǒng)

    java實(shí)現(xiàn)注冊(cè)登錄系統(tǒng)

    這篇文章主要為大家詳細(xì)介紹了java實(shí)現(xiàn)注冊(cè)登錄系統(tǒng),文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2022-04-04
  • springboot+thymeleaf+druid+mybatis 多模塊實(shí)現(xiàn)用戶登錄功能

    springboot+thymeleaf+druid+mybatis 多模塊實(shí)現(xiàn)用戶登錄功能

    這篇文章主要介紹了springboot+thymeleaf+druid+mybatis 多模塊實(shí)現(xiàn)用戶登錄功能,本文通過示例代碼圖文相結(jié)合給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-07-07
  • spring框架cacheAnnotation緩存注釋聲明解析

    spring框架cacheAnnotation緩存注釋聲明解析

    這篇文章主要介紹了spring框架中cacheAnnotation注釋聲明緩存解析示例有需要的朋友可以借鑒參考下,希望能夠有所幫助
    2021-10-10
  • JDK源碼Enum類原理及代碼實(shí)例解析

    JDK源碼Enum類原理及代碼實(shí)例解析

    這篇文章主要介紹了JDK源碼Enum類原理及代碼實(shí)例解析,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-11-11
  • Aop動(dòng)態(tài)代理和cglib實(shí)現(xiàn)代碼詳解

    Aop動(dòng)態(tài)代理和cglib實(shí)現(xiàn)代碼詳解

    這篇文章主要介紹了Aop動(dòng)態(tài)代理和cglib實(shí)現(xiàn)代碼詳解,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2020-12-12
  • 關(guān)于Java8 parallelStream并發(fā)安全的深入講解

    關(guān)于Java8 parallelStream并發(fā)安全的深入講解

    這篇文章主要給大家介紹了關(guān)于Java8 parallelStream并發(fā)安全的相關(guān)資料,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2018-10-10
  • Java排序算法總結(jié)之希爾排序

    Java排序算法總結(jié)之希爾排序

    這篇文章主要介紹了Java排序算法總結(jié)之希爾排序,較為詳細(xì)的分析了希爾排序的原理與java的實(shí)現(xiàn)技巧,需要的朋友可以參考下
    2015-05-05

最新評(píng)論