国产成人精品久久免费动漫-国产成人精品天堂-国产成人精品区在线观看-国产成人精品日本-a级毛片无码免费真人-a级毛片毛片免费观看久潮喷

您的位置:首頁技術文章
文章詳情頁

分析Java非阻塞算法Lock-Free的實現

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

我們先使用CAS來構建幾個非阻塞的棧。棧是最簡單的鏈式結構,其本質是一個鏈表,而鏈表的根節點就是棧頂。

我們先構建Node數據結構:

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

這個Node保存了內存item和它的下一個節點next。

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

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; }}非阻塞的鏈表

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

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

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

我們看下具體的代碼實現:

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); }}

先構建一個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) {//有其他的線程已經插入了一個節點,但是還沒有將tail指向最新的節點tail.compareAndSet(currentTail, tailNext); }else{//沒有其他的線程插入節點,那么做兩件事情:1. 插入新節點,2.將tail指向最新的節點if(currentTail.next.compareAndSet(null, newNode)){ tail.compareAndSet(currentTail, newNode);} }} } }}

以上就是分析Java非阻塞算法Lock-Free的實現的詳細內容,更多關于Java非阻塞算法Lock-Free的實現的資料請關注好吧啦網其它相關文章!

標簽: Java
相關文章:
主站蜘蛛池模板: 国产一区二区在线视频播放 | 欧美日韩在线观看一区二区 | 国产一级特黄特色aa毛片 | 久久99网站| u影一族亚洲精品欧美激情 va欧美 | 日韩毛片免费在线观看 | 欧美成人免费网在线观看 | 国产精品成人免费视频不卡 | 国产精品亚洲二区 | 欧美+日本+国产+在线观看 | 亚洲国产精品免费在线观看 | 久久精品国产99久久久 | 欧美精品a毛片免费观看 | 欧美一级毛片兔费播放 | 国产精品美女一区二区 | 国产美女在线精品亚洲二区 | 久久ri精品高清一区二区三区 | 欧美精品在线视频观看 | 欧美在线做爰高清视频 | 91在线 | 亚洲 | 国产成人三级 | 一级黄色香蕉视频 | 欧美一级毛片在线播放 | 欧美亚洲日本国产 | 特黄女一级毛片 | 伊在人香蕉99久久 | 91一区二区视频 | 欧美a大片 | 成人在线视频免费看 | 深夜成人性视频免费看 | a国产片 | 欧美日韩亚洲第一页 | 国产成人一区二区视频在线观看 | 日韩麻豆| 国产精品日本不卡一区二区 | www.亚洲天堂 | 日本成人免费在线 | 男女视频在线观看 | 青草久草| 精品视频一区二区三三区四区 | 欧美操人|