CAS算法

作者: 贾歌 | 来源:发表于2017-10-08 20:52 被阅读213次
一、i++ 的原子性问题:int i=i++ 的操作实际上分为三个步骤“读-改-写”

第一步:int temp = i;
第二步:i = i + 1;
第三步:i = temp;

二、原子变量:在 java.util.concurrent.atomic 包下提供了一些原子变量。
  1. volatile 保证内存可见性
  2. CAS(Compare-And-Swap) 算法保证数据变量的原子性。CAS 算法是硬件对于并发操作的支持,CAS 包含了三个操作数:
  • 内存值 V
  • 预估值 A
  • 更新值 B
当且仅当 V == A 时, V = B; 否则,不会执行任何操作。

A、多线程操作,保证内存变量原子性的示例代码

import java.util.concurrent.atomic.AtomicInteger;

public class TestAtomicDemo {

    public static void main(String[] args) {
//      int  i = 1;
//      i = i++;
//      System.out.println(i);  
//              输出1
        
        AtomicDemo ad = new AtomicDemo();
        for (int i = 0; i < 10; i++) {
            new Thread(ad).start();
        }
    }
    
}

class AtomicDemo implements Runnable{
    
    //  当多线程操作时,volatile关键字无法保证原子性
    //  private volatile int serialNumber = 0;
    
    private AtomicInteger serialNumber = new AtomicInteger(0);

    @Override
    public void run() {
        
        try {
            Thread.sleep(200);
        } catch (InterruptedException e) {
        }
        
        System.out.println(getSerialNumber());
    }
    
    public int getSerialNumber(){
//      return serialNumber++;
        
        return serialNumber.getAndIncrement();
    }
    
}

B、模拟 CAS 算法的示例代码

public class TestCompareAndSwap {

    public static void main(String[] args) {
        final CompareAndSwap cas = new CompareAndSwap();
        
        for (int i = 0; i < 10; i++) {
            new Thread(new Runnable() {
                
                @Override
                public void run() {
                    
                    int expectedValue = cas.get();
                    boolean b = cas.compareAndSet(expectedValue, (int)(Math.random() * 101));
                    System.out.println(b);
                    
                }
            }).start();
        }
        
    }
    
}

class CompareAndSwap{
    private int value;
    
    //获取内存值
    public synchronized int get(){
        return value;
    }
    
    //比较
    public synchronized int compareAndSwap(int expectedValue, int newValue){
        int oldValue = value;
        
        if(oldValue == expectedValue){
            this.value = newValue;
        }
        
        return oldValue;
    }
    
    //设置
    public synchronized boolean compareAndSet(int expectedValue, int newValue){
        return expectedValue == compareAndSwap(expectedValue, newValue);
    }
}


相关文章

  • 最简单的CAS机制说明

    CAS(Compare-And-Swap) 算法保证数据变量的原子性 CAS 算法是硬件对于并发操作的支持 CAS...

  • CAS(乐观锁)

    CAS乐观锁 CAS算法即是:Compare And Swap,比较并且替换CAS算法存在着三个参数,内存值V,旧...

  • 粒子群优化算法(PSO)基础

    粒子群算法 粒子群算法源于复杂适应系统(Complex Adaptive System,CAS)。CAS理论于19...

  • 深入理解自旋锁

    本文出自:http://blog.onlycatch.com/post/自旋锁 简单回顾一下CAS算法 CAS算法...

  • 自旋锁

    简单回顾一下CAS算法 CAS算法即compare and swap(比较与交换),是一种有名的无锁算法。无锁编程...

  • CAS机制

    CAS(Compare-And-Swap)算法保证数据操作的原子性。 CAS 算法是硬件对于并发操作共享数据的支持...

  • CAS算法和ABA问题

    CAS算法 CAS(Compare And Swap)比较并交换,它是一种算法,体现的是乐观锁的思想,总是认为自己...

  • 【java并发编程实战2】无锁编程CAS与atomic包

    1、无锁编程CAS 1.1、CAS CAS的全称是Compare And Swap 即比较交换,其算法核心思想如下...

  • android 多线程 — CAS 算法 + 原子性操作类

    CAS 也叫无锁算法(Compare and Swap),核心思想是:当多个线程尝试使用 CAS算法同时更新同一个...

  • Java并发基础

    volatile, CAS 非阻塞算法,Treiber 非阻塞算法,Unsafe Volatile volatil...

网友评论

      本文标题:CAS算法

      本文链接:https://www.haomeiwen.com/subject/eryyyxtx.html