广告
返回顶部
首页 > 资讯 > 精选 >全面了解Java中的CAS机制
  • 746
分享到

全面了解Java中的CAS机制

javacas机制 2023-05-31 00:05:00 746人浏览 安东尼
摘要

前言在看到Java锁机制的时候,无意中看到了CAS这个词,然后在百度查找CAS看了很多文章始终没有看的太懂,今天又在Google上查找了一些资料,才算是真正弄清楚了CAS机制。什么是CAS在jdk 1.5中增加的一个最主要的支持是Atomi

前言

在看到Java机制的时候,无意中看到了CAS这个词,然后在百度查找CAS看了很多文章始终没有看的太懂,今天又在Google上查找了一些资料,才算是真正弄清楚了CAS机制。

什么是CAS

jdk 1.5中增加的一个最主要的支持是Atomic类,比如说AtomicInteger, AtomicLong,这些类可帮助最大限度地减少在多线程中对于一些基本操作(例如,增加或减少多个线程之间共享的值)的复杂性。而这些类的实现都依赖于CAS(compare and swap)的算法

乐观锁和悲观锁

cpu是时分复用的,也就是把cpu的时间片,分配给不同的thread/process轮流执行,时间片与时间片之间,需要进行cpu切换,也就是会发生进程的切换。切换涉及到清空寄存器,缓存数据。然后重新加载新的thread所需数据。当一个线程被挂起时,加入到阻塞队列,在一定的时间或条件下,在通过notify(),notifyAll()唤醒回来。在某个资源不可用的时候,就将cpu让出,把当前等待线程切换为阻塞状态。等到资源(比如一个共享数据)可用了,那么就将线程唤醒,让他进入runnable状态等待cpu调度。这就是典型的悲观锁的实现。独占锁是一种悲观锁,synchronized就是一种独占锁,它假设最坏的情况,并且只有在确保其它线程不会造成干扰的情况下执行,会导致其它所有需要锁的线程挂起,等待持有锁的线程释放锁。

但是,由于在进程挂起和恢复执行过程中存在着很大的开销。当一个线程正在等待锁时,它不能做任何事,所以悲观锁有很大的缺点。举个例子,如果一个线程需要某个资源,但是这个资源的占用时间很短,当线程第一次抢占这个资源时,可能这个资源被占用,如果此时挂起这个线程,可能立刻就发现资源可用,然后又需要花费很长的时间重新抢占锁,时间代价就会非常的高。

乐观锁思路就是,每次不加锁而是假设没有冲突而去完成某项操作,如果因为冲突失败就重试,直到成功为止。某个线程可以不让出cpu,而是一直while循环,如果失败就重试,直到成功为止。所以,当数据争用不严重时,乐观锁效果更好。比如CAS就是一种乐观锁思想的应用。

CAS(Compare and Swap )算法

CAS中有三个核心参数:

主内存中存放的V值,所有线程共享。

线程上次从内存中读取的V值A存放在线程的帧栈中,每个线程私有。

需要写入内存中并改写V值的B值。也就是线程对A值操作后放入到主存V中。

上面说的比较抽象,看下面的这幅图比较容易理解。

全面了解Java中的CAS机制

如上图中,主存中保存V值,线程中要使用V值要先从主存中读取V值到线程的工作内存A中,然后计算后变成B值,最后再把B值写回到内存V值中。多个线程共用V值都是如此操作。CAS的核心是在将B值写入到V之前要比较A值和V值是否相同,如果不相同证明此时V值已经被其他线程改变,重新将V值赋给A,并重新计算得到B,如果相同,则将B值赋给V。

如果不使用CAS机制,看看存在什么问题,假如V=1,现在Thread1要对V进行加1,Thread2也要对V进行加1,首先Thread1读取V=1到自己工作内存A中此时A=1,假设Thread2此时也读取V=1到自己的工作内存A中,分别进行加1操作后,两个线程中B的值都为2,此时写回到V中时发现V的值为2,但是两个线程分别对V进行加处理结果却只加了1有问题。

CAS核心代码

if (A==V){  V = B  return B;}   else  return V;

--结束END--

本文标题: 全面了解Java中的CAS机制

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

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

本篇文章演示代码以及资料文档资料下载

下载Word文档到电脑,方便收藏和打印~

下载Word文档
猜你喜欢
  • 全面了解Java中的CAS机制
    前言在看到Java锁机制的时候,无意中看到了CAS这个词,然后在百度查找CAS看了很多文章始终没有看的太懂,今天又在Google上查找了一些资料,才算是真正弄清楚了CAS机制。什么是CAS在jdk 1.5中增加的一个最主要的支持是Atomi...
    99+
    2023-05-31
    java cas 机制
  • Java CAS机制的一些理解
    目录多线程实践什么是CAS机制为何AtomicInteger线程安全图解CAS机制ABA问题什么是ABA问题有什么影响解决总结多线程实践 public class test { ...
    99+
    2022-11-12
  • Java的锁机制:synchronized和CAS详解
    目录一为什么要用锁二synchronized怎么实现的三CAS来者何人四synchronized和CAS孰优孰劣轻量级锁重量级锁总结提到Java的知识点一定会有多线程,JDK版本不断...
    99+
    2022-11-12
  • Java中 CAS机制的原理是什么
    Java中 CAS机制的原理是什么?相信很多没有经验的人对此束手无策,为此本文总结了问题出现的原因和解决方法,通过这篇文章希望你能解决这个问题。多线程实践public class test { &nb...
    99+
    2023-06-15
  • 全面了解java中的异常处理
    目录Java 异常处理1. 什么是异常2. Java 异常类架构2.1 Throwable 类2.2 Error 类2.3 Exception 类3. 如何进行异常处理4. 抛出异常4.1 实例4.2 throw4.3 throws5. 捕...
    99+
    2020-09-26
    java 异常处理
  • Java多线程之并发编程的基石CAS机制详解
    目录一、CAS机制简介1.1、悲观锁和乐观锁更新数据方式1.2、什么是CAS机制1.3、CAS与sychronized比较1.4、Java中都有哪些地方应用到了CAS机制呢?...
    99+
    2022-11-12
  • Java CGLib动态代理机制(全面解析)
    一、首先说一下JDK中的动态代理:JDK中的动态代理是通过反射类Proxy以及InvocationHandler回调接口实现的但是,JDK中所要进行动态代理的类必须要实现一个接口,也就是说只能对该类所实现接口中定义的方法进行代理,这在实际编...
    99+
    2023-05-31
    java 动态代理 cglib
  • mysql中锁机制的最全面讲解
    目录前言全局锁全库逻辑备份FTWRL和set global readonly=true的区别表级锁MDL锁行锁死锁记录锁间隙锁临键锁乐观锁和悲观锁总结前言 根据加锁的粒度区分 ...
    99+
    2022-11-12
  • Java tomcat中的类加载器和安全机制你了解吗
    目录类加载器双亲委派URLClassLoaderTomcat中类加载器架构安全机制总结类加载器 java中的类并不是一次加载完成的,而是按需加载。类加载器是用于加载java类到jav...
    99+
    2022-11-12
  • 一文带你了解Java中的SPI机制
    目录1: SPI机制简介2: SPI原理3: 使用场景4: 源码论证5: 实战6: 优缺点6.1 优点6.2 缺点1: SPI机制简介 SPI 全称是 ...
    99+
    2023-05-15
    Java SPI机制原理 Java SPI机制使用 Java SPI机制
  • Java事件处理机制和适配器全面解析
    目录Java事件处理机制和适配器处理事件示意图java常用的监听接口Java事件适配器的作用适配器Java事件处理机制和适配器 最重要的是理解事件源,监视器,处理事件的接口的概念。 ...
    99+
    2022-11-12
  • Java中的异常处理机制介绍(非常全面!)
    目录异常处理机制编译时异常处理机制异常处理方式一异常处理方式二异常处理方式三运行时异常处理机制总结异常处理机制 异常的默认处理流程如下: 默认会在出现异常的代码那里自动的创建一个异常...
    99+
    2023-01-18
    Java异常处理机制原理 java中包含异常处理机制 java异常处理方式两种
  • 你真的了解Java中NumPy的索引机制吗?
    Java中的NumPy是一种非常强大的数组处理工具,它可以帮助我们高效地处理大量的数据。在Java中,NumPy的索引机制是非常重要的一个概念,它可以帮助我们快速地定位和获取数组中的数据。本文将深入探讨Java中NumPy的索引机制,帮助读...
    99+
    2023-05-26
    numy numpy 索引
  • JAVA的反射机制你了解多少
    目录1、什么是反射?2、反射能够干什么?3、反射相关API 4、Class类的理解(1)、介绍:(2)、类的加载过程:①加载:②链接:③初始化④使用⑤卸载(3)类加载器总结...
    99+
    2022-11-13
  • Docker中关于Namespace隔离机制全面解析
    目录 前言1. Docker基本架构 服务端 客户端2. Namespace Namespace介绍 Namespace的类型 Mount namespace UTS namespa...
    99+
    2022-11-13
  • Java应用的缓存机制,你了解吗?
    在Java应用中,缓存机制是一个非常重要的概念,它可以提高应用程序的性能和响应速度。缓存机制的基本原理是将频繁访问的数据存储在内存中,避免每次访问都需要从磁盘或数据库中读取数据。在本文中,我们将探讨Java应用中的缓存机制。 一、什么是缓...
    99+
    2023-06-18
    索引 打包 缓存
  • 如何理解AJPFX中面向对象及java的机制
    本篇文章为大家展示了如何理解AJPFX中面向对象及java的机制,内容简明扼要并且容易理解,绝对能使你眼前一亮,通过这篇文章的详细介绍希望你能有所收获。变量的作用域和生命周期什么关系?2.java除了在类体和方法体(包括参数)中可以声明变量...
    99+
    2023-06-02
  • Java全面详细讲解逻辑控制的使用
    目录一,块作用域二,顺序结构三,分支结构switch语句问题(重点)四,循环4.1,易错点4.2,break语句4.3,continue语句五,输入输出5.1,输出到控制台5.2,从...
    99+
    2022-11-13
  • Java中的反射机制详解
    目录一、什么是反射?二、为什么要用反射三、Class类四、获取Class类对象的四种方式五.通过反射构造一个类的实例①使用Class.newInstance②通过反射先获取构造方法再...
    99+
    2022-11-12
  • 一文带你了解MySQL中的锁机制
    目录一.概述 分类二.MyISAM表锁如何加表锁写锁演示三.InnoDB行锁行锁特点一.概述 锁是计算机协调多个进程或线程并发访问某一资源的机制(避免争抢)。 在数据库中,除传统的计算资源(如CPU、RAM、I...
    99+
    2023-02-17
    MySQL锁机制使用 MySQL锁机制 MySQL锁
软考高级职称资格查询
编程网,编程工程师的家园,是目前国内优秀的开源技术社区之一,形成了由开源软件库、代码分享、资讯、协作翻译、讨论区和博客等几大频道内容,为IT开发者提供了一个发现、使用、并交流开源技术的平台。
  • 官方手机版

  • 微信公众号

  • 商务合作