黑马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-轻量级锁

相关推荐
cfm_29144 小时前
JVM执行引擎初步了解
jvm
骑士雄师4 小时前
18.3 LangGraph 长期存储案例
jvm
未若君雅裁5 小时前
JVM 垃圾回收算法与分代回收机制
java·jvm·算法
未若君雅裁5 小时前
JVM 垃圾回收器全景与G1深度解析
java·开发语言·jvm
hereitis贝壳6 小时前
GC.lsp:AutoCAD 中实用的轻量化公差标注插件
jvm·里氏替换原则
未若君雅裁6 小时前
JVM 调优与线上排障:参数工具内存泄漏和CPU飙高
jvm
cfm_29147 小时前
JVM类加载机制初步了解
java·jvm
周末也要写八哥8 小时前
线程的生命周期之“守护“线程
java·开发语言·jvm
未若君雅裁1 天前
JVM 运行时数据区:程序计数器、堆、虚拟机栈与栈帧
java·jvm
killerbasd1 天前
总结 6.9
jvm