多线程---synchronized特性+原理

文章目录

synchronized特性

  • 互斥

    当某个线程执行到某个对象的synchronized中时,其他线程如果也执行到同一个对象的synchronized就会阻塞等待。

    进入synchronized修饰的代码块相当于加锁

    退出synchronized修饰的代码块相当于解锁

  • 刷新内存

    synchronized的工作过程:

    1.获得互斥锁

    2.从主内存拷贝变量的最新版本到工作内存

    3.执行代码

    4.将更改后的变量值刷新到主内存

    5.释放互斥锁

  • 可重入

    同一把锁,连续加锁两次,不会导致死锁,那么它就是可重入的。

synchronized原理

锁升级/锁膨胀

解释:

synchronized更多的考虑到降低程序员的使用负担,内部就实现了"自适应"的操作。这个"自适应"的操作就是"锁升级/锁膨胀"

如果当前程序中,锁竞争不激烈,则以轻量级锁的状态来工作。可以第一时间拿到锁。

如果当前程序中,锁竞争很激烈,则以重量级锁的状态来工作。减少CPU的开销。

偏向锁是什么呢?

锁消除

由JVM自动判断,如果它发现某个地方的代码不需要加锁,但是你写了synchronized,它就会自动把锁给去掉。

比如:多个线程修改多个不同的变量时,你对它们分别加锁

注: JVM只有在100%确定这处代码的加锁可以去掉时才会执行锁消除操作,就算有1%的可能这儿不能去掉也不会锁消除。

锁粗化

锁的粒度,就是指:synchronized包含的代码块里代码的多少

粒度粗:包含的代码多

粒度细:包含的代码少

锁粗化,就是:把粒度细的锁合并为粒度粗的锁。这样可以减少加锁和解锁的开销。

注:

  1. 对同一个对象的加锁才能进行锁粗化
  2. 锁粗化要保证粗化前和粗化后,代码的逻辑不变
相关推荐
吃饱了得干活14 小时前
Spring Cloud Gateway 微服务网关:路由、断言、过滤器
java·spring cloud
lwx5728015 小时前
探秘InnoDB:搞懂它的内存、线程、磁盘与日志刷盘策略
java·后端
Flynt17 小时前
从Spring Boot 4.0升到4.1,我在Maven和gRPC上栽了跟头
java·spring boot·后端
plainGeekDev18 小时前
Activity 间传值 → Navigation 参数
android·java·kotlin
plainGeekDev18 小时前
onActivityResult → ActivityResult API
android·java·kotlin
Sunia18 小时前
《AgentX 专栏》10-生产部署:3台2C4G云服务器把企业级Agent真正跑起来的完整方案
java·架构
ZhengEnCi19 小时前
J7A-高级Java工程师面试三道灵魂拷问-深度广度与工程素养的终极检验
java·后端
狼爷2 天前
吃透 Java Function 接口,搞定 99% 的 Stream 场景
java·函数式编程
祎雪双十Gy2 天前
从 DataX 的配置加载说起:我用 FastJson2 做了一个轻量级动态配置管理库
java·后端
小锋java12342 天前
分享一套锋哥原创的SpringBoot4+Vue3宠物领养网站系统
java