Synchronized和ReentrantLock的区别

Synchronized和ReentrantLock的区别,第1张

synchronized是和if、else、for、while一样的关键字,ReentrantLock是类,这是两者的本质区别。由于ReentrantLock是类,所以提供了比synchronized更多更灵活的特性,可以被继承、可以有方法、可以有各种各样的类变量。

synchronized早期的实现比较低效,对比ReentrantLock,大多数场景性能都相差较大,但是在Java 6中对synchronized进行了非常多的改进。

相同点:两者都是可重入锁

        可重入锁的概念:自己可以再次获取自己的内部锁。比如一个线程获得了某个对象的锁,此时这个对象锁还没有释放,当其再次想要获取这个对象的锁的时候还是可以获取的,如果不可锁重入的话,就会造成死锁。同一个线程每次获取锁,锁的计数器都是自增1,所以要等到锁的计数器下降为0时才能释放锁

主要的区别如下:

  • ReentrantLock使用起来比较灵活,但是必须有释放锁的配合动作
  • ReentrantLock必须手动获取与释放锁,而synchronized不需要手动释放和开启锁
  • ReentrantLock只适用于代码块锁,而synchronized可以修饰类、方法、变量等
  • 两者的锁机制其实也是不一样的。ReentrantLock底层调用的是Unsafe的park方法加锁,synchronized *** 作的应该是对象头中mark word

Java中每一个对象都可以作为锁,这是synchronized实现同步的基础:

  • 普通同步方法,锁是当前实例对象
  • 静态同步方法,锁是当前类的class对象
  • 同步方法块,锁是括号里面的对象

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/langs/877097.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-05-13
下一篇 2022-05-13

发表评论

登录后才能评论

评论列表(0条)

保存