美文网首页
并发工具类(4)两个线程进行数据交换的Exchanger

并发工具类(4)两个线程进行数据交换的Exchanger

作者: 放开那个BUG | 来源:发表于2018-11-25 14:52 被阅读5次

简介

Exchanger(交换者)是一个用于线程间写作的工具类。Exchanger用于进行线程间的数据交换。它提供一个同步点,在这个同步点两个线程可以交换彼此的数据。这两个线程通过exchange()交换数据,如果第一个线程先执行exchange方法,它会一直等待第二个线程也执行exchange(),当连个线程都到达同步点时,这两个线程就可以交换数据,将本线程生产出来的数据传递给对方。

应用场景

Exchanger可以用于遗传算法,遗传算法里需要选出两个人作为交配对象,这时候会交换两人的数据,并使用交叉规则得出2个交配结果。
Exchanger也可以用于校对工作。比如我们需要将纸制银流通过人工的方式录入成电子银行流水,为了避免错误,采用AB岗两人进行录入,录入到Excel之后,系统需要加载这两个Excel,并对这两个Excel数据进行校对,看看是否录入的一致。代码如下:

package com.semaphore;

import java.util.concurrent.Exchanger;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;

public class ExchangerTest {

    private static final Exchanger<String> exgr = new Exchanger<String>();

    private static ExecutorService threadPool = Executors.newFixedThreadPool(2);

    public static void main(String[] args) {

        threadPool.execute(new Runnable() {
            @Override
            public void run() {
                try {
                    String A = "银行流水A";// A录入银行流水数据
                    System.out.println("本来是" + A + "变成了" + exgr.exchange(A));
                } catch (InterruptedException e) {
                }
            }
        });

        threadPool.execute(new Runnable() {
            @Override
            public void run() {
                try {
                    String B = "银行流水B";// B录入银行流水数据
                    System.out.println("本来是" + B + "变成了" + exgr.exchange(B));
                } catch (InterruptedException e) {
                }
            }
        });

        threadPool.shutdown();

    }
}

结果如下:


引用

并发工具类系列都整理自并发编程网

相关文章

网友评论

      本文标题:并发工具类(4)两个线程进行数据交换的Exchanger

      本文链接:https://www.haomeiwen.com/subject/nqypqqtx.html