zoukankan      html  css  js  c++  java
  • CAS自旋锁

    自旋锁spinLock是指尝试获取锁的线程不会立即阻塞, 而是采用循环的方式去尝试获取锁。

    1. 优点是减少线程上下文切换的消耗;
    2. 缺点是循环会消耗CPU,会导致ABA问题-[解决方案:带时间戳的原子引用AtomicStampedReference]。
    unsafe.getAndAddInt(Object var1, long var2, int var4) {
    	int var5;
    	do {
    		var5 = this.getIntVolatile(var1, var2);	
    	}while(!this.compareAndSwapInt(var1, var2, var5, var5 + var4));
    	return var5;
    }
    
    手写一个自旋锁
    
    /**
     * 自旋锁DEMO
     * @Author小海
     * @Description:
     * @Date: Create in 00:18 2020-01-30
     */
    public class SpinLockDemo {
        static AtomicReference<Thread> atomicReference = new AtomicReference<>();
    
        public static void myLock(){
            Thread thread = Thread.currentThread();
            System.out.println(thread.getName() + "	 开始加锁");
            while(!atomicReference.compareAndSet(null, thread)){
    
            }
            System.out.println(thread.getName() + "	 加锁成功");
        }
    
        public static void myUnLock(){
            Thread thread = Thread.currentThread();
            System.out.println(thread.getName() + "	 开始解锁");
            while(!atomicReference.compareAndSet(thread, null)){
    
            }
            System.out.println(thread.getName() + "	 解锁成功");
        }
    
        public static void main(String[] args) {
            new Thread(()->{
                myLock();
    
                try {
                    Thread.sleep(5);
                } catch (InterruptedException e) {
                    e.printStackTrace();
                } finally {
                    myUnLock();
                }
    
            }, "AA").start();
    
            try {
                Thread.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            new Thread(()->{
                myLock();
                myUnLock();
            }, "BB").start();
        }
    
    }
    

     

  • 相关阅读:
    第十八课 顺序存储线性表的分析
    第十七课 StaticList和DynamicList实现
    第十六课 顺序存储结构的抽象实现
    第十五课 线性表的顺序存储结构
    第十四课 线性表的本质和操作
    第十三课 类族结构的进化
    第十二课 顶层父类的创建
    第十一课 异常类构建
    HDU 5773The All-purpose Zero
    HDU 5755 Gambler Bo
  • 原文地址:https://www.cnblogs.com/xhyouyou/p/12465278.html
Copyright © 2011-2022 走看看