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

相关推荐
修行者Java18 小时前
JVM 内存结构
jvm
代码程序猿RIP21 小时前
【SQLite 库】sqlite3_open_v2
jvm·oracle·sqlite
柳贯一(逆流河版)2 天前
Spring Boot Actuator+Micrometer:高并发下 JVM 监控体系的轻量化实践
jvm·spring boot·后端
lpruoyu2 天前
颜群JVM【04】助记符
jvm
Flash Dog2 天前
【JVM】——实战篇
jvm
DKPT2 天前
JVM栈溢出和堆溢出哪个先满?
java·开发语言·jvm·笔记·学习
m0_475064502 天前
jvm双亲委派的含义
java·jvm
胡小禾2 天前
JDK17和JDK8的 G1
jvm·算法
海梨花2 天前
今日八股——JVM篇
jvm·后端·面试
fwerfv3453453 天前
使用PyTorch构建你的第一个神经网络
jvm·数据库·python