JAVA中synchronized与Lock的区别

   Java语言提供了两种锁机制来实现对某个共享资源的同步:synchronized和Lock.其中,synchronized使用Object对象本身的notify,wait,notifyAll调度机制,而Lock可以使用Condition进行线程之间的调度,完成synchronized实现的所有功能.

具体而言,二者的主要区别主要表现在以下几个方法的内容:

1)用法不一样.在需要同步的对象中加入synchronized控制,synchronized既可以加载方法上,也可以加在特定代码块中,括号中表示需要锁的对象.而Lock需要显式的指定起始位和终止位置.synchronized是托管给JVM执行的,而Lock的锁定是通过代码实现的,它有比synchronized更精确的线程语义.

2)性能不一样.在JDK5中增加了一个Lock接口实现类ReentrantLock.它不仅拥有和synchronized相同的并发性和内存语义,还多了锁投票,定时锁,等候和中断锁等.它们的性能在不同的情况下会有不同:在资源竞争不是很激烈的情况下,synchronized的性能要由于ReentrantLock,但是在资源竞争很激烈的情况下,synchronized的性能会下降得非常快,而ReentrantLock的性能基本保持不变.

3)锁机制不一样,synchronized获得锁和释放的方式都是在块结构中,当获取多个锁时,必须以相反的顺序释放,并且是自动解锁,不会因为出来异常而导致锁没有被释放从而引发死锁.而Lock则需要开发人员手动去释放,并且必须在finally块中释放,否则会引起死锁问题的发生.此外,Lock还提供了更强大的功能,它的tryLock()方法可以采用非阻塞的方式去获取锁.

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
synchronizedlock都是Java用来实现线程同步的关键字和类,它们的主要区别如下: 1. 锁的获取和释放方式不同 synchronized关键字是隐式锁,在代码块或方法使用时,当线程进入同步代码块时,会自动获取锁,执行完同步代码块后,会自动释放锁。而lock是显式锁,需要手动获取锁和释放锁,即通过lock()方法获取锁,通过unlock()方法释放锁。 2. 锁的可重入性不同 synchronized是可重入锁,即同一个线程在持有锁的情况下,能够再次获得该锁。而lock在获取锁时需要先判断当前线程是否已经持有锁,如果是,则允许该线程继续获取锁,也就是说,lock也是可重入锁。 3. 锁的公平性不同 synchronized是非公平锁,即线程在等待锁时,是随机竞争锁的。而lock可以通过构造函数指定锁的公平性,即fair为true时为公平锁,fair为false时为非公平锁。 4. 锁的灵活性不同 synchronized是内置的Java关键字,不能对其进行扩展。而lock是一个接口,可以通过实现该接口来扩展锁的功能,例如可以实现可断锁或超时锁等。 5. 锁的性能不同 synchronizedJava内置的锁,由JVM实现,JVM可以对其进行优化,锁的性能较高。而lock是基于Java API实现的锁,通常比synchronized稍微慢一些。 总之,synchronizedlock都是Java用来实现线程同步的关键字和类,它们各有优缺点,应根据具体场景选择使用哪种锁。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值