多线程_高级主题_CAS_原子操作

锁有很多种叫法,根据不同的角度可以做不同的分类,比如是否沿用,我们分为可重入和不可重入,可重入还可以分为公平锁和不公平锁,所谓公不公平就在于这个锁在用的时候会加到队列里面,如果你按原先的队列的先后顺序去用这个锁的话称为公平锁,如果是不按这个队列顺序突然有个插队的,这个就称为不公平锁。
比如说还有自选锁、阻塞锁以及悲观锁、乐观锁等等等等有很多。
多线程_高级主题_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();
		}
	}
}

多线程_高级主题_CAS_原子操作