黑马JVM总结(三十六)

(1)CAS-概述

cas是配合volatile使用的技术 ,对共享变量的安全性要使用synachonized加锁,但是CAS不加锁,它是使用where(true)的死循环,里面compareAndSwap尝试把结果赋值给共享变量,赋值的同时呢,会把旧值跟共享变量当前的值做一个比较,因为他怕在写入结果的时候,有其他线程把已经把共享变量改了,这两个值是一致的就把结果成功的写入共享变量里去,如果不一致,放回false,重新进入where循环

(2)CAS-底层

CAS底层使用Unsafe类来实现的

(3)CAS-原子类

它是采用无锁并发的方式保证原子整数信息的并发安全

(4)synchronized-优化

jdk6之后呢底层对synchronized做了优化,性能得到提升,某些场景下比CAS更好,它采用轻量级锁,偏向锁,等等提升性能

标记位:就是标记你加了偏向锁啊还是轻量级锁重量级锁啊

根据锁的类型存储重量级锁的指针啊,锁记录的指针啊

(5)synchronized-轻量级锁

相关推荐
m0_748554816 小时前
golang如何实现用户订阅偏好管理_golang用户订阅偏好管理实现总结
jvm·数据库·python
lee_curry6 小时前
第四章 jvm中的垃圾回收器
java·jvm·垃圾收集器
阿正呀8 小时前
Redis怎样实现本地缓存的高效失效通知
jvm·数据库·python
2501_901200538 小时前
mysql如何设置InnoDB引擎参数_优化innodb_buffer_pool
jvm·数据库·python
金銀銅鐵9 小时前
[java] 编译之后的记录类(Record Classes)长什么样子(上)
java·jvm·后端
m0_495496419 小时前
mysql处理复杂SQL性能_InnoDB优化器与MyISAM差异
jvm·数据库·python
forEverPlume10 小时前
PHP怎么使用Eloquent Attribute Composition属性组合_Laravel通过组合构建复杂属性【方法】
jvm·数据库·python
2301_8092047010 小时前
mysql在docker容器中如何部署_利用docker-compose快速启动
jvm·数据库·python
2301_8159019714 小时前
SQL如何将多行记录聚合成逗号分隔字符串_GROUP_CONCAT技巧
jvm·数据库·python
zjy2777714 小时前
Layui tab选项卡如何动态根据ID值进行程序化切换
jvm·数据库·python