多线程结果集合并

时间:2025-03-10 18:27:03

在性能优化过程中不可避免的会遇到需要多线程去查询或者处理数据,也就会遇到结果集合并的需求,下面是多线程结果集的示例

package ;

import ;
import ;
import ;
import .*;

public class ExecutorServiceDemo {

    public static void main(String[] args) {
        ();
    }

    private final static int NUMBER = 3;

    public static void task() {

        // 创建线程池。
        ExecutorService pool = (NUMBER);

        ArrayList<Future<String>> futures = new ArrayList<Future<String>>();

        for (int i = 0; i < 10; i++) {
            int f = i;
            // 创建调度任务
            FutureTask<String> futureTask = new FutureTask<>(() -> {
                (new Random().nextInt(10));
                return ""+f;
            });
            // 执行任务
            (futureTask);
            (futureTask);
        }

        ("遍历获取结果中...");
        while(() > 0) {
            Iterator<Future<String>> iterator = ();
            while (()) {
                Future<String> future = ();
                try {
                    // 判断是否返回结果,防止直接回去结果阻塞
                    if (()) {
                        (());
                        ();
                    }
                } catch (Exception e) {
                    ();
                }
            }
            try {
                // 释放CPU,降低服务器压力
                (1);
            } catch (InterruptedException e) {
                ();
            }
        }
        ("完成遍历结果.");

        // 关闭线程池。
        ();
    }
}