java多线程(4) ----- Lock的使用

(欢迎关注微信公众号:深入Java底层)

4.1使用ReentrantLock类

调用ReentrantLock对象的lock()方法获取锁,调用unlock()方法释放锁,效果和使用synchronized关键字一样。

Object类中的wait()方法相当于Condition类中的await()方法。在condition. await()方法调用之前需要先调用lock.lock()代码获得同步器。

Object类中的wait(longtimeout)方法相当于Condition类中的await(longtime,TimeUnit unit)方法。

Object类中的notify()方法相当于Condition类中的signal()方法。

Object类中的notifyAll()方法相当于Condition类中的signalAll()方法。

使用ReentrantLock对象(准确说是Condition()对象)可以唤醒指定种类的线程,对线程执行的业务进行排序规划。

方法getHoldCount()、getQueueLength()和getWaitQueueLength()的测试

1)  方法int getHoldCount()的作用是查询当前线程保持此锁定的个数,也就是调用lock()方法的次数。

2)  方法int getQueueLength()的作用是返回正等待获取此锁锁定的线程估计数,比如有5个线程,1个线程首先执行await()方法,那么在调用getQueueLength()方法后返回值是4,说明有4个线程同时在等待lock的释放。

3)  方法int getWaitQueueLength(Conditioncondition) 的作用是返回等待与此锁定相关的给定条件Condition的线程估计数,比如有5个线程,每个线程都执行了同一个condition对象的await()方法,则调用getWaitQueueLength(Conditioncondition)方法时返回的int值是5。

方法hasQueueThread()、hasQueueThreads()和hasWaiters()的测试

1)        方法boolean hasQueueThread(Thread thread)的作用是查询指定的线程是否正在等待获取此锁定。

2)        方法boolean hasQueueThreads的作用是查询是否有线程正在等待获取此锁定。

3)        方法boolean hasWaiters(Conditioncondition)的作用是查询是否有线程正在等待与此锁定有关的condition条件。

方法isFair ()、isHeldByCurrentThread()和isLocked()的测试

1)        方法boolean isFair()的作用是判断是不是公平锁。在默认情况下,ReentrantLock类使用的是非公平锁。

2)        方法boolean isHeldByCurrentThread()的作用是查询当前线程是否保持此锁定。

3)        方法boolean isLocked()的作用是查询此锁定是否由任意线程保持。

方法lockInterruptibly()、tryLock()和tryLock(long timeout,TimeUnit unit)的测试

1)        方法void lockInterruptibly()的作用是:如果当前线程未被中断,则获取锁定,如果已经被中断则出现异常。

2)        方法boolean tryLock()的作用是,仅在调用时锁定未被另一个线程保持的情况下,才获取该锁定。

3)        方法boolean tryLock(long timeout, TimeUnit unit)的作用是,如果锁定在给定等待时间内没有被另一个线程保持,且当前线程未被中断,则获取该锁定。

方法awaitUninterruptibly()的使用

void awaitUninterruptibly();

//调用该方法的前提是,当前线程已经成功获得与该条件对象绑定的重入锁,否则调用该方法时会抛出IllegalMonitorStateException 

//调用该方法后,结束等待的唯一方法是其它线程调用该条件对象的signal()signalALL()方法。等待过程中如果当前线程被中断,该方法仍然会继续等待,同时保留该线程的中断状态。

方法awaitUntil()的使用

long awaitNanos(longnanosTimeout) throws InterruptedException;

//调用该方法的前提是,当前线程已经成功获得与该条件对象绑定的重入锁,否则调用该方法时会抛出IllegalMonitorStateException

//nanosTimeout指定该方法等待信号的的最大时间(单位为纳秒)。若指定时间内收到signal()signalALL()则返回nanosTimeout减去已经等待的时间; 

//若指定时间内有其它线程中断该线程,则抛出InterruptedException并清除当前线程的打断状态;若指定时间内未收到通知,则返回0或负数。

boolean awaitUntil(Date deadline) throwsInterruptedException;

//适用条件与行为与awaitNanos(long nanosTimeout)完全一样,唯一不同点在于它不是等待指定时间,而是等待由参数指定的某一时刻。

4.2 使用ReentrantReadWriteLock类

读写锁表示有两个锁,一个是读操作相关的锁,也称为共享锁;另一个是写操作相关的锁,也叫排他锁。也就是多个读锁之间不互斥,读锁与写锁互斥,写锁与写锁互斥。

(欢迎关注微信公众号:深入Java底层)

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值