java中Synchronized和Lock的区别

Synchronized和Lock的区别

原始构成

  1. synchronized关键字属于JVM层面的,通过monitorenter,monitorexit指令实现,底层是通过monitor对象来完成,其实wait notify等方法也依赖monitor对象,只有同步块或者同步方法中才能调用wait,notify等方法;
  2. Lock是具体类(java.utils.concurrent.locks.Lock)是API层面的锁

使用方法

  1. synchronized不许要显式手动的获得和释放锁,系统会自动让线程释放对锁的占用
  2. ReectrantLock:需要显式的获得和释放锁,如果没有正确的释放锁,有可能导致死锁;

等待是否可以中断

  1. synchronized不可以中断,除非抛出异常或者正常运行完成
  2. ReentrantLock可以中断,1.设置超时时间tryLock(timeout),2.lockInterruptibly放在代码块中,调用interrupter()方法可以中断

加锁是否公平

  1. synchronzed是非公平锁
  2. ReentrantLock两者都可以,默认为非公平锁,构造方法传入boolean值,true为公平锁,false为非公平锁

锁绑定多个条件Condition

  1. synchronzied 没有
  2. ReentrantLock:实现分组唤醒需要唤醒的线程们,可以实现精确唤醒,而不是像synchronized要么随机唤醒一个线程,要么唤醒所有的线程;
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值