Synchronized加锁和释放锁的原理、可重入原理、保证可见性原理

本文详细解析了Java中Synchronized关键字的工作原理,包括加锁和释放锁的过程,可重入锁的实现机制,以及如何保证多线程环境下的可见性。通过分析JVM层面的字节码,帮助读者更深入地理解Synchronized关键字在实际应用中的行为。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

一、加锁和释放锁的原理

现象、时机、深入jvm看字节码

现象:每一个类的实例对应一把锁,每个被Synchronized修饰的方法 都必须首先获得调用该方法的类的实例的锁 方能执行。否则线程阻塞,而这个方法独占了这把锁,直到该方法返回或者抛出异常才能释放。
获取和释放锁的时机:内置锁,线程在进入同步代码块之前会自动获得这个锁,并且在退出这个同步代码块会自动释放。获得这个内置锁的唯一途径就是进入到这个锁

二、可重入原理

加锁次数计数器

三、保证可见性原理

内存模型

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值