sychronized底层原理,为什么慢?

本文详细解析了Java中`synchronized`的底层原理,包括monitorenter和monitorexit指令,以及重量级锁的阻塞与唤醒机制。特别介绍了自旋锁的优化策略及其潜在问题。

底层原理:

Synchronized通过编译,会在同步块的前后分别形成monitorentermonitorexit这个两个字节码指令。

1)在执行monitorenter指令时,首先要尝试获取对象锁。如果这个对象没被锁定,或者当前线程已经拥有了那个对象锁,把锁的计算器加1

2)相应的,在执行monitorexit指令时会将锁计算器减1,当计算器为0时,锁就被释放了

3)如果获取对象锁失败,那当前线程就要阻塞,直到对象锁被另一个线程释放为止。
 

 

sychronized是重量级锁:同一时刻有多个线程竞争同一把锁

当多个线程竞争同一把锁时,竞争失败的线程会被阻塞。直到只有锁的线程将锁释放后再次唤醒阻塞的线程

 

慢的原因:

线程的唤醒和阻塞是一个很耗费CPU资源的操作

 

优化:

使用自旋锁来获取重量级锁,线程未获得锁后,不是一味地阻塞,而是让线程通过循环不断尝试获取锁

 

自旋锁的缺点:

若线程占用锁的时间过长,导致CPU资源拜拜浪费

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值