多线程_高级主题_CAS_原子操作
锁有很多种叫法,根据不同的角度可以做不同的分类,比如是否沿用,我们分为可重入和不可重入,可重入还可以分为公平锁和不公平锁,所谓公不公平就在于这个锁在用的时候会加到队列里面,如果你按原先的队列的先后顺序去用这个锁的话称为公平锁,如果是不按这个队列顺序突然有个插队的,这个就称为不公平锁。
比如说还有自选锁、阻塞锁以及悲观锁、乐观锁等等等等有很多。
package com.sxt.others;
import java.util.concurrent.atomic.AtomicInteger;
/**
* CAS:比较并交换
*
* @author
*
*/
public class CAS {
//库存
private static AtomicInteger stock = new AtomicInteger(5);
public static void main(String[] args) {
for(int i=0;i<5;i++) {
new Thread(()->{
//模拟网络延时
try {
Thread.sleep(1000);
} catch (InterruptedException e) {
e.printStackTrace();
}
Integer left = stock.decrementAndGet();
if(left<1) {
System.out.println("抢完了...");
return ;
}
System.out.print(Thread.currentThread().getName()+"抢了一件商品");
System.out.println("-->还剩"+left);
}) .start();
}
}
}