Java 多线程高并发 3.2 — Condition 简单使用

主要 api

名称用法
await()会使当前线程等待,同时释放当前锁,当其他线程中使用 signal() 时或者 signalAll() 方法时,线程会重新获得锁并继续执行。或者当线程被中断时,也能跳出等待。这和 Object.wait() 方法很相似
awaitUninterruptibly()与 await() 方法基本相同,但是它并不会再等待过程中响应中断
singal()用于唤醒一个在等待中的线程。相对的 singalAll() 方法会唤醒所有在等待中的线程。这和 Obejct.notify() 方法很类似
signalAll()唤醒所有等待等待中的线程
signalAll()唤醒所有等待等待中的线程

整体上看和原生 Obejct 的线程操作非常像,用法也几乎一样,这里没有涉及到原理和实现就不多说了,需要先会用,但值得注意的是 Condition 是由 ReentrantLock 的工厂方法构造出来的,所以需要绑定使用

下面看个简单的例子

public class TestCondition {
	private static ReentrantLock lock = new ReentrantLock();
	private static Condition condition = lock.newCondition();
	
	static class TestConditionThread implements Runnable {
		@Override
		public void run() {
			lock.lock();
			try {
				System.out.println(System.currentTimeMillis() + " :" + Thread.currentThread().getName() + " 进来了");
				condition.await();
				System.out.println(System.currentTimeMillis() + " :" + Thread.currentThread().getName() + " 等待完了");
			} catch (InterruptedException e) {
				e.printStackTrace();
			} finally {
				lock.unlock();
			}
		}
	}
	
	public static void main(String[] args) throws InterruptedException {
		Thread t1 = new Thread(new TestConditionThread(), "Thread TestConditionThread");
		t1.start();
		try {
			Thread.sleep(3000);
		} catch (InterruptedException e) {
			e.printStackTrace();
		}
		lock.lock();
		try {
			System.out.println(System.currentTimeMillis() + " : 开始唤醒 Condition 下的一个");
			condition.signal();
		} finally {
			lock.unlock();
		}
	}	
}

输出
1537840950378 : Thread TestConditionThread 进来了
1537840953378 : 开始唤醒 Condition 下的一个
1537840953378 : Thread TestConditionThread 等待完了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值