关于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()唤醒等待,被唤醒的线程返回时必须获取锁才行。

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

498

被折叠的 条评论
为什么被折叠?



