您好,登錄后才能下訂單哦!
CAS:比較并交換
借助已經實現的類AtomicInteger
內部原理:把當前的值和原來的值(序列號、地址等)作比較,如果相等則覆蓋
public class my {
//借助已經實現的類AtomicInteger
//庫存
private static AtomicInteger stock=new AtomicInteger(5); //假設庫存有五件商品
public static void main(String[]args) throws InterruptedException
{
for(int i=0;i<5;i++)
{
new Thread(()->{
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Integer left=stock.decrementAndGet(); //相減和獲取
//內部已實現CAS原子操作
if(left<1)
{
System.out.println("搶完了");
return;
}
System.out.println(Thread.currentThread().getName()+"搶了一件商品");
System.out.println("還剩下:"+left);
}).start();
}
}
}
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。