concurrent包中的Exchager类,主要用于两个线程间的数据通信(只适用于两个线程),或者说就是两个线程交换数据。Exchanger提供了一个同步点,当线程A调用exchange()方法时,会进入阻塞状态,直到第二个线程也调用exchange()方法后,就到达了同步点,此时就可以将两个线程各自的数据进行传递。
public class ExchangerTest {
private static ExecutorService executorService = Executors.newFixedThreadPool(2);
private static final Exchanger<String> exchanger = new Exchanger<>();
public static void main(String[] args) {
executorService.execute(new Runnable() {
@Override
public void run() {
try {
String X = "abc";
String exchange = exchanger.exchange(X);
System.out.println("X=" + exchange);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
executorService.execute(new Runnable() {
@Override
public void run() {
try {
String Y = "def";
String exchange = exchanger.exchange(Y);
System.out.println("Y=" + exchange);
} catch (InterruptedException e) {
e.printStackTrace();
}
}
});
executorService.shutdown();
}
}
/**输出结果**/
Y=abc
X=def
可以看到,两个线程如期的进行了数据的通信。为了防止程序发生意外陷入无限等待,可以显示的调用exchange(V x,long timeout,TimeUnit unit)来设置最大等待时间,超过时间抛出java.util.concurrent.TimeoutException异常。
Exchanger适用于遗传算法、生产消费者模式功能里面,平时项目开发的话我也用的比较少。