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算法相关推荐

  1. 【面试篇】Java多线程并发-Java中的CAS机制算法

    Java中的CAS机制算法 a.CAS例子 再讲解CAS机制之前,先来看一道经典的并发执行1000次递增的问题: public class Test { public static int count ...

  2. android studio插入数据表中没有_学Java能拿高薪吗 Java中常见排序算法有哪些

    学Java能拿高薪吗?Java中常见排序算法有哪些?作为老牌编程语言,Java拥有广阔的市场占有率,几乎90%以上的大中型互联网应用系统在服务端开发都会首选Java.为了加入到Java这一高薪行业,很 ...

  3. 【高并发】java中的CAS,你需要知道的东西

    1.概述 转载:添加链接描述 从网站计数器实现中一步步引出CAS操作 介绍java中的CAS及CAS可能存在的问题 悲观锁和乐观锁的一些介绍及数据库乐观锁的一个常见示例 使用java中的原子操作实现网 ...

  4. luhn算法java_Java信用卡验证– Java中的Luhn算法

    luhn算法java Recently I came to know that Credit Card numbers are not random and passes Luhn Algorithm ...

  5. JAVA 中的 CAS

    原文地址:https://www.xilidou.com/2018/02/01/java-cas/ CAS 是现代操作系统,解决并发问题的一个重要手段,最近在看 eureka 的源码的时候.遇到了很多 ...

  6. Java中的经典算法之冒泡排序(Bubble Sort)

    Java中的经典算法之冒泡排序(Bubble Sort) 原理:比较两个相邻的元素,将值大的元素交换至右端. 思路:依次比较相邻的两个数,将小数放在前面,大数放在后面.即在第一趟:首先比较第1个和第2 ...

  7. Java中的CAS操作

    Java中的CAS的含义 CAS即是Compare and Swap ,它是JDK提供的非阻塞原子性操作,它通过硬件保证了比较一更新操作的原子性.CAS 操作包含三个操作数-内存位置(V).预期原值( ...

  8. Java中的CAS以及AQS实现原理

    Java中的CAS实现原理 什么是CAS? 在计算机科学中,比较和交换(Conmpare And Swap)是用于实现多线程同步的原子指令. 它将内存位置的内容与给定值进行比较,只有在相同的情况下,将 ...

  9. 什么是java中的CAS

    问题一:java中的CAS是什么? 问题二:为什么要使用CAS? 问题三:CAS使用中需要注意什么问题? 这里以提问的方式引出话题,下面带大家慢慢了解CAS. 1.CAS的含义 CAS是compare ...

最新文章

  1. 软件开发--深入理解程序的结构
  2. SQL触发器demo
  3. python中avg函数的使用_SQL AVG()
  4. Codeforces Round #459 (Div. 2)题解
  5. 关于share prefrences功能的一些理解
  6. C 主导、C++与 C# 为辅,揭秘 Windows 10 源代码!
  7. linux集群启动脚本,Hadoop2.2.0集群启动和停止Shell脚本
  8. 在训练CNN时,loss稳定在log(类别数)
  9. Centos 6.6 Docker安装(内网坏境)
  10. abaqus算出来的转角单位是什么_ABAQUS统一单位方法
  11. c语言专家编程,读书笔记
  12. androidQ(10.0) 预装集成apk到data分区
  13. 正交设计之正交四原则
  14. DLP3010EVM-LC and DLP2010EVM-LC常见问题答疑
  15. 1万字!彻底看懂微信小程序
  16. 15个C语言“谜题”,有你知道的吗?
  17. MySql 中 PK、NN、UQ、BIN、UN、ZF、AI、G分别代表什么意思
  18. scons用户指南第一章:编译和安装SCons
  19. 铁路管理系统(C语言)
  20. iOS NSPredicate 模糊、精确、查询

热门文章

  1. 用spark分析北京积分落户数据,按用户身份证所在省份城市分析
  2. 实施工作20190313
  3. 学习图神经网络相关内容
  4. 解决苹果手机点击输入框页面自动放大问题
  5. Cisco(62)——PBR策略路由案例
  6. Laravel Excel实现Excel/CSV文件导入导出的功能详解(合并单元格,设置单元格样式)
  7. su鉴定故障和su拒绝权限
  8. 撩妹攻略话术恋爱小程序源码分享
  9. MQTT协议详解 三、MQTT控制包(CONNECT)
  10. 数据库SQL实战 --42.将id=5以及emp_no=10001的行数据替换成id=5以及emp_no=10005