如何使用Lock接口来实现等待/通知机制

本文探讨如何利用Java Lock接口中的Condition配合实现等待/通知机制,以替代传统的synchronized关键字。通过示例介绍Condition接口的主要方法,如await(), awaitUninterruptibly(), signal()和signalAll(),并讨论其与synchronized的性能差异。" 81700392,5738653,awk实战:Linux日志分析与Web服务器故障排查,"['Linux', '日志分析', '服务器监控']

关于java中的等待/通知机制(http://blog.csdn.net/canot/article/details/50879963)在之前的解决方案中都是基于synchronized以及Object类的方法wait(),wait(long timeout),notify()以及notifyAll()方法来实现。现在我们了解了java中的另一种锁Lock之后我们尝试能不能用Lock代替synchronized来实现等待/通知机制。

Condition接口
Lock接口要实现等待/通知必须与Condition接口配合。Condition接口提供了类似Object类的监视器方法,我们先介绍其使用方法。然后再讨论其与synchronized的性能差别。

Condition接口与示例:
Condition是由Lock锁产生的,故使用Condition必须先获取Lock锁。

Lock lock = new ReentrantLock();
//等待/通知中Condition必须为同一变量,此处定义为全局变量
Condition condition = lock.newCondition();
public void conditionWait() throws InterruptedException{
  lock.lock();
  try{
  //调用await()后当前线程释放锁并等待
     condition.await();
  }finally{
   lock.unlock();
  }
}
public void conditionSignal() throws InterruptedException{
  lock.lock();
  try{
  //调用signal()方法后通知在该Condition上等待的线程从await()方法返回,并且返回时已经获取了锁
    condition.signal();
  }finally{
     lock.unlock();
  }

}

Condition接口对应的方法:

  • void await() 使线程进入等待状态直达其他线程使用该Condition调用signal()或者signalAll()方法。同时该线程可以响应中断
  • void awaitUninterruptibly() 与上述一样,但该方法使得线程不响应中断
  • long awaitNanos(long nanosTimeout) 超时式的等待如果返回为0或者负数表示已经超时
  • boolean awaitUntil(Date deadline) 到指定的时间如果依然未被通知,中断则返回false
  • void signal() 与 void signalAll()唤醒等待,被唤醒的线程返回时必须获取锁才行。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值