CAS机制详解

本文详细介绍了CAS(Compare And Swap)机制,包括什么是原子操作、JDK中的原子操作类,如AtomicInteger、AtomicReference等,并通过示例分析了非原子操作的缺陷,展示了如何使用CAS进行无锁优化。
摘要由CSDN通过智能技术生成

目录

相关文章:

一、什么是CAS?

1.1、Demo1

1.2、什么是原子操作?

1.3、JDK中相关原子操作类

1.3.1、原子更新基本类型,

1.3.2、原子更新数组类型

1.3.3、原子更新引用类型

1.3.4、原子更新字段类

1.4、优化Demo2

1.5 详细解析CAS


相关文章:

java高并发:CAS无锁原理及广泛应用(2w阅读量)

漫画:什么是 CAS 机制?(漫画版,深入浅出)

漫画:什么是CAS机制?(进阶篇)(Java语言CAS底层如何实现、什么是ABA问题?怎么解决?)

一、什么是CAS?

具体可看  漫画:什么是 CAS 机制?

Atomic操作类的底层,正是利用了我们所说的CAS机制

CAS是英文单词Compare And Swap的缩写,翻译过来就是比较并替换。

CAS(V,E,N) 机制当中使用了3个基本操作数:内存地址V,旧的预期值A,要修改的新值B。

更新一个变量的时候,只有当变量的预期值A和内存地址V当中的实际值相同时,才会将内存地址V对应的值修改为B。

先来实现一段代码

1.1、Demo1

public class Demo1 {
    int i = 0;

    public void incr() {
        i++;//加1操作
    }

    public static void main(String[] args)throws Exception {
        Demo1 demo1 = new Demo1();

        for (int j = 0; j < 2; j++) {//new 两个线程
            new Thread(new Runnable() {
                @Override
                public void run() {
                    for (int k = 0; k < 10000; k++) {//每个线程执行10000遍
                        demo1.incr();
                    }
                }
            }).start();
        }
        Thread.sleep(1000);
        System.out.println(demo1.i);//打印结果是否为20000?
    }
}

打印结果&#
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值