色综合图-色综合图片-色综合图片二区150p-色综合图区-玖玖国产精品视频-玖玖香蕉视频

您的位置:首頁技術(shù)文章
文章詳情頁

分析Java非阻塞算法Lock-Free的實現(xiàn)

瀏覽:65日期:2022-08-11 14:06:04
目錄非阻塞的棧非阻塞的鏈表非阻塞的棧

我們先使用CAS來構(gòu)建幾個非阻塞的棧。棧是最簡單的鏈?zhǔn)浇Y(jié)構(gòu),其本質(zhì)是一個鏈表,而鏈表的根節(jié)點就是棧頂。

我們先構(gòu)建Node數(shù)據(jù)結(jié)構(gòu):

public class Node<E> { public final E item; public Node<E> next; public Node(E item){this.item=item; }}

這個Node保存了內(nèi)存item和它的下一個節(jié)點next。

然后我們構(gòu)建非阻塞的棧,在該棧中我們需要實現(xiàn)pop和push方法,我們使用一個Atomic類來保存top節(jié)點的引用,在pop和push之前調(diào)用compareAndSet命令來保證命令的原子性。同時,我們需要不斷的循環(huán),以保證在線程沖突的時候能夠重試更新。

public class ConcurrentStack<E> { AtomicReference<Node<E>> top= new AtomicReference<>(); public void push(E item){Node<E> newNode= new Node<>(item);Node<E> oldNode;do{ oldNode=top.get(); newNode.next= oldNode;}while(!top.compareAndSet(oldNode, newNode)); } public E pop(){Node<E> oldNode;Node<E> newNode;do { oldNode = top.get(); if(oldNode == null){return null; } newNode=oldNode.next;}while(!top.compareAndSet(oldNode, newNode));return oldNode.item; }}非阻塞的鏈表

構(gòu)建鏈表要比構(gòu)建棧復(fù)雜。因為我們要維持頭尾兩個指針。以put方法來說,我們需要執(zhí)行兩步操作:1. 在尾部插入新的節(jié)點。2.將尾部指針指向最新的節(jié)點。

我們使用CAS最多只能保證其中的一步是原子執(zhí)行。那么對于1和2的組合步驟該怎么處理呢?

我們再仔細(xì)考慮考慮,其實1和2并不一定要在同一個線程中執(zhí)行,其他線程在檢測到有線程插入了節(jié)點,但是沒有將tail指向最后的節(jié)點時,完全幫忙完成這個操作。

我們看下具體的代碼實現(xiàn):

public class LinkedNode<E> { public final E item; public final AtomicReference<LinkedNode<E>> next; public LinkedNode(E item, LinkedNode<E> next){this.item=item;this.next=new AtomicReference<>(next); }}

先構(gòu)建一個LinkedNode類。

public class LinkedQueue<E> { private final LinkedNode<E> nullNode= new LinkedNode<>(null, null); private final AtomicReference<LinkedNode<E>> head= new AtomicReference<>(nullNode); private final AtomicReference<LinkedNode<E>> tail= new AtomicReference<>(nullNode); public boolean put(E item){ LinkedNode<E> newNode = new LinkedNode<>(item, null); while (true){LinkedNode<E> currentTail= tail.get();LinkedNode<E> tailNext= currentTail.next.get();if(currentTail == tail.get()){ if (tailNext != null) {//有其他的線程已經(jīng)插入了一個節(jié)點,但是還沒有將tail指向最新的節(jié)點tail.compareAndSet(currentTail, tailNext); }else{//沒有其他的線程插入節(jié)點,那么做兩件事情:1. 插入新節(jié)點,2.將tail指向最新的節(jié)點if(currentTail.next.compareAndSet(null, newNode)){ tail.compareAndSet(currentTail, newNode);} }} } }}

以上就是分析Java非阻塞算法Lock-Free的實現(xiàn)的詳細(xì)內(nèi)容,更多關(guān)于Java非阻塞算法Lock-Free的實現(xiàn)的資料請關(guān)注好吧啦網(wǎng)其它相關(guān)文章!

標(biāo)簽: Java
相關(guān)文章:
主站蜘蛛池模板: 午夜影院亚洲 | 成人午夜视频在线观看 | 特级淫片欧美高清视频蜜桃 | 一级a爰片久久毛片 | 在线小毛片 | 欧美综合成人网 | 手机看片日韩高清国产欧美 | 中国一级做a爰片久久毛片 中日韩欧美一级毛片 | 免费欧洲毛片a级视频无风险 | 成人欧美一区二区三区黑人免费 | 日本一区二区免费在线观看 | 亚洲性在线 | 免费人成黄页在线观看视频国产 | 92自拍视频 | 女网址www呦| a级免费 | 波多野结衣视频在线观看 | 成人黄色免费网址 | 亚洲国产成人私人影院 | 视频精品一区 | 视频一区在线免费观看 | 中文字幕精品一区二区三区视频 | 国产欧美精品午夜在线播放 | 精品无码久久久久国产 | 一本久| 欧美色偷偷 | 亚洲性天堂 | 99久在线精品99re6视频 | 正在播放国产一区 | 国产日韩欧美自拍 | 在线成年人网站 | 久久久久免费视频 | 国产91久久精品一区二区 | 成熟的女性强烈交性视频 | 久久久精品在线观看 | 国产在线观看免费人成小说 | 9191精品国产费久久 | 国产成人精品区在线观看 | 精品三级视频 | 国产精品成人免费观看 | 欧美一级免费片 |