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

相关推荐
源分享3 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm
JAVA9653 天前
JAVA面试-JVM篇 03-JVM运行时数据区哪些是线程私有的哪些是共享的
java·jvm·面试
伶俜664 天前
鸿蒙原生应用实战(十八)ArkUI 记账本:SQLite 账单 + 图表统计 + 分类管理
jvm·sqlite·harmonyos
IronMurphy4 天前
多线程问!
java·jvm·spring
unique4 天前
AI Coding 采集方案探索
jvm·人工智能·oracle
cfm_29144 天前
JVM GC日志解析
jvm
不良使4 天前
鸿蒙PC迁移:使用Electron`logseq-master-ohos` 鸿蒙适配全记录
jvm·electron·harmonyos
cfm_29144 天前
JVM深度详解:Class常量池、运行时常量池、字符串常量池、包装类对象池
java·jvm
JAVA9655 天前
JAVA面试-JVM篇 02-G1垃圾收集器的工作原理是什么与CMS的区别
java·jvm·面试