Java 多线程 系列文章目录:
- Java 多线程(一)线程间的互斥和同步通信
- Java 多线程(二)同步线程分组问题
- Java 多线程(三)线程池入门 Callable 和 Future
- Java 多线程(四)ThreadPoolExecutor 线程池各参数的意义
- Java 多线程(五)Lock 和 Condition 实现线程同步通信
- Java 多线程(六)Semaphore 实现信号灯
- Java 多线程(七)CyclicBarrier 同步的工具类
- Java 多线程(八)CountDownLatch 同步工具类
- Java 多线程(九)Exchanger 同步工具类
- Java 多线程(十)ArrayBlockingQueue 阻塞队列
- Java 多线程(十一)JDK 同步集合
Exchanger 用于两个线程之间交换数据。
打个比方:实现两个人之间的数据交换,一个人在完成一定的事务后想与对方交换交换数据,第一个先拿出数据的人将一直等待(exchange 方法出等待)第二个人拿着数据到来时(也执行 exchange 方法),两者才能彼此交换数据。
也就是当两个线程都到达了交换点(exchange方法),才能交换。
我们来看下面的一个程序(有两个线程:一个线程持有 Drug,另一个线程持有 Money,两者想要交换):
public static void main(String[] args) {
ExecutorService service = Executors.newCachedThreadPool();
final Exchanger exchanger = new Exchanger();
service.execute(new Runnable() {
public void run() {
try {
String data1 = "money";
System.out.println("线程" + Thread.currentThread().getName()
+ "正在把数据" + data1 + "换出去");
Thread.sleep((long) (Math.random() * 10000));
String data2 = (String) exchanger.exchange(data1);
System.out.println("线程" + Thread.currentThread().getName()
+ "换回的数据为" + data2);
} catch (Exception e) {
}
}
});
service.execute(new Runnable() {
public void run() {
try {
String data1 = "drugs";
System.out.println("线程" + Thread.currentThread().getName()
+ "正在把数据" + data1 + "换出去");
Thread.sleep((long) (Math.random() * 10000));
String data2 = (String) exchanger.exchange(data1);
System.out.println("线程" + Thread.currentThread().getName()
+ "换回的数据为" + data2);
} catch (Exception e) {
}
}
});
}
运行的结果如下所示:
线程pool-1-thread-2正在把数据drugs换出去
线程pool-1-thread-1正在把数据money换出去
线程pool-1-thread-1换回的数据为drugs
线程pool-1-thread-2换回的数据为money