关于Shchronized和ReentrantLock不得不说的二三事

Synchronized原理:

Synchronized在编译后
会在同步代码块前后分别形成monitorentermonitorexit这两个字节码指令

友情提示:monitor是监视的意思 enter是进入 exit是退出(感觉光凭名字就能脑补出作用了对吧!

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

相反在执行monitorexit指令时会将锁计算器 - 1
当计算器为0时, 锁就会被释放.

当然啦, 如果获取对象锁失败, 那当前线程可是会被阻塞的(
直到对象锁被另一个线程释放为止(可真安全啊(x

ReentrantLock原理:

天呐它实现了Lock接口唉(
就是那个必须得手动开启手动关闭的糙心玩意儿, 还只能锁代码块儿
主要利用CAS(Compare and Swap) 和 CLH队列来实现
CAS:Compare and Swap,比较并交换。CAS有3个操作数:内存值V、预期值A、要修改的新值B。当且仅当预期值A和内存值V相同时,将内存值V修改为B,否则什么都不做。在Java中,CAS主要是由sun.misc.Unsafe这个类通过JNI调用CPU底层指令实现。
[JNI是 java native interface哦
CLH: 带头结点的双向循环链表(这谁记得住(x

它们俩的区别

区别SynchronizedReentrantLock(因为实现了Lock接口该有的其实都有)
构成是Java的关键字, 是原生语法层面的互斥, 需要JVM实现是JDK提供的API层面的互斥锁类
实现通过JVM加锁解锁API层面的加锁解锁
编写采用synchronized不需要用户去手动释放锁, 它是隐形锁出了作用域自动释放必须要用户手动去加锁释放锁, 不然给你死锁(skr 需要lock()和unlock()方法配合try/finally语句块来完成
公平锁非公平锁两者都可以, 默认非公平锁, 构造器可以传入boolean值然进行选择
适用情况在偶尔会出现同步的情况下更优在同步激烈的时候性能比前者好很多
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值