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

文章目录

synchronized特性

  • 互斥

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

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

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

  • 刷新内存

    synchronized的工作过程:

    1.获得互斥锁

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

    3.执行代码

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

    5.释放互斥锁

  • 可重入

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

synchronized原理

锁升级/锁膨胀

解释:

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

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

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

偏向锁是什么呢?

锁消除

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

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

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

锁粗化

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

粒度粗:包含的代码多

粒度细:包含的代码少

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

注:

  1. 对同一个对象的加锁才能进行锁粗化
  2. 锁粗化要保证粗化前和粗化后,代码的逻辑不变
相关推荐
Mr YiRan16 小时前
C++面向对象继承与操作符重载
开发语言·c++·算法
Drifter_yh18 小时前
【黑马点评】Redisson 分布式锁核心原理剖析
java·数据库·redis·分布式·spring·缓存
一只鹿鹿鹿18 小时前
智慧水利一体化建设方案
大数据·运维·开发语言·数据库·物联网
莫寒清19 小时前
Spring MVC:@RequestParam 注解详解
java·spring·mvc
没有医保李先生20 小时前
字节对齐的总结
java·开发语言
Elastic 中国社区官方博客20 小时前
使用 Elastic 进行网络监控:统一网络可观测性
大数据·开发语言·网络·人工智能·elasticsearch·搜索引擎·全文检索
Codefengfeng20 小时前
Python Base环境中加包的方法
开发语言·python
清水白石00820 小时前
《Python 编程全景解析:从核心精要到测试替身(Test Doubles)五大武器的实战淬炼》
开发语言·python
甲枫叶21 小时前
【claude】Claude Code正式引入Git Worktree原生支持:Agent全面实现并行独立工作
java·人工智能·git·python·ai编程
六件套是我1 天前
无法访问org.springframeword.beans.factory.annotation.Value
java·开发语言·spring boot