并发编程之Exchanger-线程间交换数据

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

猜你喜欢

转载自blog.csdn.net/fanrenxiang/article/details/80497863