synchronized和ReentrantLock到底使用哪个?

参考:关于synchronized和ReentrantLock之多线程同步详解

看了一些并发的文章和书籍,举了一些ReentrantLock和Condition的例子。很多时候纠结在Condtion的使用上了。仔细想一想,其实使用Condition这些例子使用传统的“对象”和“synchronized”进行锁的方式也是可以实现的,只是有些时候没有ReentrantLock实现起来那么漂亮。重点其实还是在“是否可中断”、“公平锁”、“读写锁”上。

所以什么时候应该使用synchronized?什么时候应该使用ReentrantLock呢?下面列举一下各自功能:

功能synchronizedReentrantLock
可中断锁XO
公平锁XO
非公平锁OO
读写锁XO
绑定多个条件X(可以用多个锁实现)O

注释:
1,性能方面,由于synchronized也在不断优化,所以性能上差不多。但如果是使用ReentrantLock的读写锁,性能方面还是差很多的。
2,绑定多个条件。ReentrantLock使用的是Condition进行处理的,而如果使用Synchornized方式的话,要使用多个“对象锁”或结合volatile或原子类进行实现。例如:javadoc上的生产者和消费者的例子,就可以用3个“对象锁”做出来。但从可读性或优雅性上来看,还是ReentrantLock好一点。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
在Java中,synchronized和ReentrantLock都是用于实现线程同步的机制,但它们有一些不同之处。 1. 锁的获取方式:synchronized是隐式锁,它在代码块或方法上加上synchronized关键字后,线程进入代码块或方法时会自动获取锁,并在退出时释放锁。而ReentrantLock是显式锁,需要手动调用lock()方法获取锁,并在使用完毕后调用unlock()方法释放锁。 2. 锁的可重入性:synchronized是可重入锁,即同一个线程可以多次获取同一个锁,而不会造成死锁。ReentrantLock也是可重入锁,并且提供了更灵活的重入性,可以通过设置公平性来决定锁的获取顺序。 3. 锁的公平性:synchronized是非公平锁,即线程获取锁的顺序是不确定的。而ReentrantLock可以通过构造函数传入参数来设置为公平锁或非公平锁,默认为非公平锁。公平锁会按照线程的请求顺序来获取锁,而非公平锁则允许插队。 4. 锁的灵活性:ReentrantLock相比synchronized提供了更多的灵活性。例如,ReentrantLock可以通过tryLock()方法尝试获取锁,如果锁已被其他线程占用,则返回false,而synchronized没有类似的方法。此外,ReentrantLock还提供了Condition接口,可以通过Condition实现更灵活的线程等待和唤醒机制。 总的来说,synchronized是Java语言内置的关键字,使用简单,但功能相对有限。而ReentrantLock是一个类,提供了更多的功能和灵活性,但使用起来相对复杂一些。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值