返回顶部
首页 > 资讯 > 后端开发 > Python >Java CAS机制的一些理解
  • 272
分享到

Java CAS机制的一些理解

2024-04-02 19:04:59 272人浏览 安东尼

Python 官方文档:入门教程 => 点击学习

摘要

目录多线程实践什么是CAS机制为何AtomicInteger线程安全图解CAS机制ABA问题什么是ABA问题有什么影响解决总结多线程实践 public class test {

多线程实践


public class test {
    private static int x;
    public static void main(String[] args) throws InterruptedException {
        Thread task1 = new Thread(){
            @Override
            public void run() {
                super.run();
                for (int i=0; i<1000; i++){
                    x=x+1;
                }
            }
        };
        Thread task2 = new Thread(){
            @Override
            public void run() {
                super.run();
                for (int i=0; i<1000; i++){
                    x=x+1;
                }
            }
        };

        task1.start();
        task2.start();
        task1.join();
        task2.join();
        System.out.println(x);
    }
//:~

两个线程同时开启,累加x,理想的情况下,输出应该是2000,但是最终是1006,因为是多线程的情况下,一次累加可能是两个线程同时完成的。


public class test {
    private static AtomicInteger atomicInteger = new AtomicInteger();
    public static void main(String[] args) throws InterruptedException {
        Thread task1 = new Thread(){
            @Override
            public void run() {
                super.run();
                for (int i=0; i<1000; i++){
                    atomicInteger.incrementAndGet();
                }
            }
        };

        Thread task2 = new Thread(){
            @Override
            public void run() {
                super.run();
                for (int i=0; i<1000; i++){
                    atomicInteger.incrementAndGet();
                }
            }
        };

        task1.start();
        task2.start();
        task1.join();
        task2.join();
        System.out.println(atomicInteger.get());
    }
}//:~

修改被累加对象x为AtomicInteger,最终结果是理想的2000。在此操作中并没有使用,原因是 AtomicInteger引入了CAS机制。

什么是CAS机制

CAS机制简单的说就是,比较交换,有预期值、旧值和内存位置;取出旧值,交换新值。

为何AtomicInteger线程安全

源码


private static final long valueOffset;
...
public final int incrementAndGet() {
    return unsafe.getAndAddInt(this, valueOffset, 1) + 1;
}
...
Unsafe
public final int 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;
}

unsafe提供了硬件级别的原子操作 valueOffset是变量内存地址 从源码可以看出,incrementAndGet是调用了unsafe.getAndAddInt,它是一种基于CAS机制实现的,var5是从主内存中获取最新当前值,而这个值是所有线程都可见和共享的,与var4相加交换,如果失败就一直自旋,直到更新值成功。

图解CAS机制

可以看出来,CAS没有使用了任何锁,就完成了线程安全。 CAS的优点很多,但是缺点也很多,比如ABA问题

ABA问题

什么是ABA问题

其实很好理解,A->B->A,A值虽然没有变,但是已经经过了某种操作。

图解

有什么影响

上面的线程1、2、3都完成它们自己的任务,并没有问题。但是如果它们是在转账,问题就打了,账户就无端端的不见了10块钱。

解决

引入版本号,可以解决问题,每次有相同的值时,做一次版本累加,只要是版本号对不上就是被修改过

总结

优点: 在并发量不是很高的情况,避免了锁带来的消耗

缺点:

  • 并发量高的情况下,如果多次修改不成功,一直循环修改,就会带来cpu的持续消耗
  • 只能对变量进行原子级别的安全修改,不能对代码块进行安全操作。

以上就是Java CAS机制的一些理解的详细内容,更多关于Java CAS机制的资料请关注编程网其它相关文章!

--结束END--

本文标题: Java CAS机制的一些理解

本文链接: https://lsjlt.com/news/125699.html(转载时请注明来源链接)

有问题或投稿请发送至: 邮箱/279061341@qq.com    QQ/279061341

猜你喜欢
  • Java CAS机制的一些理解
    目录多线程实践什么是CAS机制为何AtomicInteger线程安全图解CAS机制ABA问题什么是ABA问题有什么影响解决总结多线程实践 public class test { ...
    99+
    2024-04-02
  • Java CAS机制详解
    目录一、什么是CAS什么是CAS机制为何CAS如此优秀CAS为什么要和volitile配合使用二、Java中的Atomic原子操作包三、类AtomicInteger四、Unsafe类...
    99+
    2023-01-28
    Java CAS Java CAS机制
  • Java的锁机制:synchronized和CAS详解
    目录一为什么要用锁二synchronized怎么实现的三CAS来者何人四synchronized和CAS孰优孰劣轻量级锁重量级锁总结提到Java的知识点一定会有多线程,JDK版本不断...
    99+
    2024-04-02
  • 全面了解Java中的CAS机制
    前言在看到Java锁机制的时候,无意中看到了CAS这个词,然后在百度查找CAS看了很多文章始终没有看的太懂,今天又在Google上查找了一些资料,才算是真正弄清楚了CAS机制。什么是CAS在jdk 1.5中增加的一个最主要的支持是Atomi...
    99+
    2023-05-31
    java cas 机制
  • Java中 CAS机制的原理是什么
    Java中 CAS机制的原理是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。多线程实践public class test { &nb...
    99+
    2023-06-15
  • 详解JAVA如何实现乐观锁以及CAS机制
    目录前言问题引入悲观锁解决乐观锁解决乐观锁改进CAS机制总结前言 生活中我们看待一个事物总有不同的态度,比如半瓶水,悲观的人会觉得只有半瓶水了,而乐观的人则会认为还有半瓶水呢。很多技...
    99+
    2022-12-08
    JAVA乐观锁 CAS机制 JAVA乐观锁 JAVA CAS
  • Java多线程之并发编程的基石CAS机制详解
    目录一、CAS机制简介1.1、悲观锁和乐观锁更新数据方式1.2、什么是CAS机制1.3、CAS与sychronized比较1.4、Java中都有哪些地方应用到了CAS机制呢?...
    99+
    2024-04-02
  • 浅谈Java非阻塞同步机制和CAS
    目录什么是非阻塞同步悲观锁和乐观锁CAS什么是非阻塞同步 非阻塞同步的意思是多个线程在竞争相同的数据时候不会发生阻塞,从而能够在更加细粒度的维度上进行协调,从而极大的减少线程调度的开...
    99+
    2024-04-02
  • JAVA怎么实现乐观锁及CAS机制
    本篇内容介绍了“JAVA怎么实现乐观锁及CAS机制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言生活中我们看待一个事物总有不同的态度,比...
    99+
    2023-07-04
  • Java并发之CAS原理详解
    目录开端1.代码1.1修改后的代码1.2代码改进:CAS模仿2.CAS分析2.1Java对CAS的支持2.2CAS实现原理是什么?2.3CAS存在的问题2.3.1什么是ABA问题?2...
    99+
    2024-04-02
  • Java多线程 乐观锁和CAS机制详细
    目录一、悲观锁和乐观锁1、悲观锁2、乐观锁二、CAS机制一、悲观锁和乐观锁 1、悲观锁 悲观锁是基于一种悲观的态度类来防止一切数据冲突,它是以一种预防的姿态在修改数据之前把数据锁住,...
    99+
    2024-04-02
  • PHP垃圾回收机制的一些理解
    目录垃圾回收是什么东西? PHP 的垃圾回收算法 垃圾回收对性能的影响 总结 相信只要入门学习过一点开发的同学都知道,不管任何编程语言,一个变量都会保存在内存中。其实,我们这些开发者...
    99+
    2024-04-02
  • 详解java 中的CAS与ABA
    目录1. 独占锁: 1.1 乐观锁的操作 2. 乐观锁: 2.1 CAS操作 3. 原子变量类 4. CAS的缺陷 1. 独占锁: 属于悲观锁,有共享资源,需要加锁时,会以独占锁的...
    99+
    2024-04-02
  • 从另一个角度理解Java中的动态代理机制
    本篇文章为大家展示了从另一个角度理解Java中的动态代理机制,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。class文件简介及加载Java编译器编译好Java文件之后,产生.class 文件在磁盘中...
    99+
    2023-05-31
    java 动态代理 ava
  • 如何理解Java代理机制
    本篇内容主要讲解“如何理解Java代理机制”,感兴趣的朋友不妨来看看。本文介绍的方法操作简单快捷,实用性强。下面就让小编来带大家学习“如何理解Java代理机制”吧!动态代理中是如何使用反射的全文脉络思维导图如下: 常规编码方式在学习代理之前...
    99+
    2023-06-15
  • java的事务处理机制有哪些
    Java的事务处理机制主要有以下几种: 编程式事务管理:通过编写代码来处理事务,使用事务管理接口进行事务的开启、提交、回滚等操作...
    99+
    2024-03-07
    java
  • java内存管理机制剖析(一)
    最近利用工作之余学习研究了一下java的内存管理机制,在这里记录总结一下。1.1 java内存区域 当java程序运行时,java虚拟机会将内存划分为若干个不同的数据区域,这些内存区域创建和销毁的时间各不相同,所承担的功能也不相同,他们各...
    99+
    2023-06-02
  • 如何理解Java中的SPI机制
    本篇内容介绍了“如何理解Java中的SPI机制”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!SPI的概念SPI在Java中的全称为Servi...
    99+
    2023-06-15
  • Java 详解异常的处理机制
    目录1.异常概述与异常体系结构1.1异常概述1.2运行时异常与编译时异常1.3异常体系结构2.常见异常1.ArrayIndexOutOfBoundsException2.NullPo...
    99+
    2024-04-02
  • java 代理机制的实例详解
    java 代理机制的实例详解前言: java代理分静态代理和动态代理,动态代理有jdk代理和cglib代理两种,在运行时生成新的子类class文件。本文主要练习下动态代理,代码用于备忘。对于代理的原理和机制,网上有很多写的很好的,...
    99+
    2023-05-31
    java 代理机制 ava
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作