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适用于遗传算法、生产消费者模式功能里面,平时项目开发的话我也用的比较少。