JVM锁机制

感情不顺,事业不顺,咱们来搞学习啊。

一、列举锁的分类

(一)偏向锁

其实在大部分情况下,一个同步方法其实只会被一个线程占用,而同一个线程是不会存在并发的,所以也不需要过多的维护并发的线程切换信息。

因此偏向锁认为,只要一个锁只被一个线程占用,那么就不需要做过多的处理。

(二)轻量级锁

在偏向锁的基础上,如果出现并发了,那么就会如何呢?

轻量级锁的设计便是针对这种情况,实际上大部分情况下,一个锁即使被多个线程使用,但是大部分情况下都不会出现一个线程等待另一个线程释放锁的情况。

所以在偏向锁的基础上,如果执有该锁的线程发生了改变,那么JVM认为这个锁会被多个线程占用,因此会升级成为轻量级锁。

(三)自旋锁

虽然大部分情况下锁不会出现竞争,可是一旦出现竞争了,那该如何解决?

自旋锁认为,一个锁即使出现竞争,也不会被占用很长时间,只要等待很短的时间就可以获取到锁,因此,当轻量级锁发生了并发抢占锁的情况,等待锁的线程就会进行自旋,也就是for循环操作罢了。

自旋成功获取锁的次数越多,信用也就越良好,因此自旋的次数上限也会越来越大。

(四)重量级锁

可是如果真的出现了极端情况,自旋也不一定能获取到锁,那么这个时候还让线程不停的for循环的话,是十分浪费资源的,因此此时JVM认为,这个锁是需要彻底维护的,不能像上面三种情况一样进行偷懒了,于是轻量级锁也就成为了重量级锁。

同样,自旋的人儿

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值