美文网首页
并发工具类(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