JAVA中的CAS算法
java 中的线程之间的栈空间是相互独立,堆空间是共享的
V:内存值就是主内存中i值
A:预估值(期望值)就是子线程拿到主内存的值(读取到高速缓存中的值)
B:更新值是子线程拿到i值后,修改i的值
假设有两个线程同时要修改i的值,此时i为临界资源,若其中一个线程对其修改,另外一个线程就会修改失败。
假设主内存中i值为(V)5。线程数为二。
线程一拿到的值是(A)5,同时线程二拿到的值也是(A)5。此时线程将值(B)6赋值给了主内存中的i,此时i的值为(V)6。线程二在此时也开始对(V)I值进行修改,但线程二预估值是(A)5,目前的内存值是(V)6,预估值不等于内存值,则不满足条件无法修改。
ABA问题:
在CAS算法中,需要取出内存中某时刻的数据(由用户完成),在下一时刻比较并替换(由CPU完成,该操作是原子的)。
这个时间差中,会导致数据的变化。
假设如下事件序列:
线程 1 从内存位置V中取出A。
线程 2 从位置V中取出A。
线程 2 进行了一些操作,将B写入位置V。
线程 2 将A再次写入位置V。
线程 1 进行CAS操作,发现位置V中仍然是A,操作成功。尽管线程 1 的CAS操作成功,但不代表这个过程没有问题——对于线程 1 ,线程 2 的修改已经丢失。
aba解决方法:加版本号而不是根据值判断
JAVA中的CAS算法相关推荐
- 【面试篇】Java多线程并发-Java中的CAS机制算法
Java中的CAS机制算法 a.CAS例子 再讲解CAS机制之前,先来看一道经典的并发执行1000次递增的问题: public class Test { public static int count ...
- android studio插入数据表中没有_学Java能拿高薪吗 Java中常见排序算法有哪些
学Java能拿高薪吗?Java中常见排序算法有哪些?作为老牌编程语言,Java拥有广阔的市场占有率,几乎90%以上的大中型互联网应用系统在服务端开发都会首选Java.为了加入到Java这一高薪行业,很 ...
- 【高并发】java中的CAS,你需要知道的东西
1.概述 转载:添加链接描述 从网站计数器实现中一步步引出CAS操作 介绍java中的CAS及CAS可能存在的问题 悲观锁和乐观锁的一些介绍及数据库乐观锁的一个常见示例 使用java中的原子操作实现网 ...
- luhn算法java_Java信用卡验证– Java中的Luhn算法
luhn算法java Recently I came to know that Credit Card numbers are not random and passes Luhn Algorithm ...
- JAVA 中的 CAS
原文地址:https://www.xilidou.com/2018/02/01/java-cas/ CAS 是现代操作系统,解决并发问题的一个重要手段,最近在看 eureka 的源码的时候.遇到了很多 ...
- Java中的经典算法之冒泡排序(Bubble Sort)
Java中的经典算法之冒泡排序(Bubble Sort) 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2 ...
- Java中的CAS操作
Java中的CAS的含义 CAS即是Compare and Swap ,它是JDK提供的非阻塞原子性操作,它通过硬件保证了比较一更新操作的原子性.CAS 操作包含三个操作数-内存位置(V).预期原值( ...
- Java中的CAS以及AQS实现原理
Java中的CAS实现原理 什么是CAS? 在计算机科学中,比较和交换(Conmpare And Swap)是用于实现多线程同步的原子指令. 它将内存位置的内容与给定值进行比较,只有在相同的情况下,将 ...
- 什么是java中的CAS
问题一:java中的CAS是什么? 问题二:为什么要使用CAS? 问题三:CAS使用中需要注意什么问题? 这里以提问的方式引出话题,下面带大家慢慢了解CAS. 1.CAS的含义 CAS是compare ...
最新文章
- 软件开发--深入理解程序的结构
- SQL触发器demo
- python中avg函数的使用_SQL AVG()
- Codeforces Round #459 (Div. 2)题解
- 关于share prefrences功能的一些理解
- C 主导、C++与 C# 为辅,揭秘 Windows 10 源代码!
- linux集群启动脚本,Hadoop2.2.0集群启动和停止Shell脚本
- 在训练CNN时,loss稳定在log(类别数)
- Centos 6.6 Docker安装(内网坏境)
- abaqus算出来的转角单位是什么_ABAQUS统一单位方法
- c语言专家编程,读书笔记
- androidQ(10.0) 预装集成apk到data分区
- 正交设计之正交四原则
- DLP3010EVM-LC and DLP2010EVM-LC常见问题答疑
- 1万字!彻底看懂微信小程序
- 15个C语言“谜题”,有你知道的吗?
- MySql 中 PK、NN、UQ、BIN、UN、ZF、AI、G分别代表什么意思
- scons用户指南第一章:编译和安装SCons
- 铁路管理系统(C语言)
- iOS NSPredicate 模糊、精确、查询
热门文章
- 用spark分析北京积分落户数据,按用户身份证所在省份城市分析
- 实施工作20190313
- 学习图神经网络相关内容
- 解决苹果手机点击输入框页面自动放大问题
- Cisco(62)——PBR策略路由案例
- Laravel Excel实现Excel/CSV文件导入导出的功能详解(合并单元格,设置单元格样式)
- su鉴定故障和su拒绝权限
- 撩妹攻略话术恋爱小程序源码分享
- MQTT协议详解 三、MQTT控制包(CONNECT)
- 数据库SQL实战 --42.将id=5以及emp_no=10001的行数据替换成id=5以及emp_no=10005