一只小小狗,异步多线程效率对比

本文介绍了一个使用Spring框架配置线程池的方法,并展示了如何利用线程池进行数据库批量插入操作以提高效率。通过具体代码实现,比较了不同批量处理方式的性能差异。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

核心代码

自动以线程池

@Component
@Slf4j
public class ThreadPoolConfig {

    @Bean
    @Qualifier(value = "configurationCheckThreadPool")
    public ExecutorService executorService(){
        int nThreads = Runtime.getRuntime().availableProcessors();
        log.info("可用运行线程为"+nThreads);
        ThreadFactory namedThreadFactory = new ThreadFactoryBuilder()
                .setNameFormat("ConfigurationCheck-pool-%d").build();

        ExecutorService configurationCheckThreadPool = new ThreadPoolExecutor(nThreads, 10,
                0L, TimeUnit.MILLISECONDS,
                new LinkedBlockingQueue<Runnable>(1024), namedThreadFactory, new ThreadPoolExecutor.AbortPolicy());
        return configurationCheckThreadPool;
    }
}
@Qualifier(value = "configurationCheckThreadPool")
private final ExecutorService executorService;
        //解析JSON后文件映射
        List<BDG_TASK_MANAGEMENT> bdg_task_managements = analysisJSONToObject(jsonArray);

        //拆分入库
        /**
         * 使用多线程 483 时间戳
         */
        long l = System.currentTimeMillis();
        CopyOnWriteArrayList<FutureTask<Integer>> integers = new CopyOnWriteArrayList<>();
        for (int i = 0; i < bdg_task_managements.size(); i++) {
            int finalI = i;
            FutureTask<Integer> integerFutureTask = new FutureTask<>(new Callable<Integer>() {
                @Override
                public Integer call() throws Exception {
                    int insert = configurationCheckImpl.insert(bdg_task_managements.get(finalI));
                    return insert;
                }
            });
            executorService.submit(integerFutureTask);
            integers.add(integerFutureTask);
        }






//        AtomicReference<Boolean> aBoolean = new AtomicReference<>(true);
        /**
         * 4668 时间戳 parallelStream
         * 5197 时间戳 Stream.parallel
         */
//        bdg_task_managements.parallelStream().forEach(bdg_task_management -> {
//            try {
//                configurationCheckImpl.insert(bdg_task_management);
//            } catch (Exception e) {
//                e.printStackTrace();
//                aBoolean.set(false);
//                return;
//            }
//        });

        /**
         * 6497 时间戳
         * 7365 时间戳
         * 7094 时间戳
         */
//        for (int i = 0; i < bdg_task_managements.size(); i++) {
//            BDG_TASK_MANAGEMENT bdg_task_management = bdg_task_managements.get(i);
//            try {
//                configurationCheckImpl.insert(bdg_task_management);
//            } catch (Exception e) {
//                aBoolean.set(false);
//                e.printStackTrace();
//            }
//        }

        System.out.println(System.currentTimeMillis() - l);
//        return aBoolean.get();
        return true;
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

一只小小狗

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值