多线程使用

并发多线程使用

使用场景:

  • 事物操作后,与事物无关的操作比如操作日志
  • 查询主表后开多线程查询多个子表
  • 插入主表后,需要插入多个无关联的子表,此时需要做多线程的事物统一性。
//
// Source code recreated from a .class file by IntelliJ IDEA
// (powered by FernFlower decompiler)
//

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CompletableFuture;
import java.util.concurrent.Executor;
import java.util.concurrent.SynchronousQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
import org.slf4j.Logger;
import org.slf4j.LoggerFactory;

public final class AsyncTaskUtil {
    private static final Logger LOGGER = LoggerFactory.getLogger(AsyncTaskUtil.class);
    private static Executor executor;

    public AsyncTaskUtil() {
    }

    public static void runTask(AsyncTask asyncTask) throws RuntimeException {
        if (asyncTask == null) {
            throw new RuntimeException("async task is null");
        } else {
            CompletableFuture.runAsync(() -> {
                Object returnValue = asyncTask.run();
                asyncTask.callback(returnValue);
            }).exceptionally((e) -> {
                LOGGER.error("async task execute failed e={}", e);
                return null;
            });
        }
    }

    public static Object[] runAll(List<AsyncTask> asyncTaskList) throws RuntimeException {
        if (asyncTaskList != null && !asyncTaskList.isEmpty()) {
            try {
                int size = asyncTaskList.size();
                Object[] returnValueList = new Object[size];
                CompletableFuture<Void>[] array = new CompletableFuture[size];
                int i = 0;

                for(int n = asyncTaskList.size(); i < n; ++i) {
                    AsyncTask asyncTask = (AsyncTask)asyncTaskList.get(i);
                    CompletableFuture<Void> function = CompletableFuture.runAsync(() -> {
                        Object returnValue = asyncTask.run();
                        int index = asyncTask.getTaskNum();
                        returnValueList[index] = returnValue;
                    }, executor);
                    array[i] = function;
                }

                CompletableFuture.allOf(array).get();
                return returnValueList;
            } catch (Exception var9) {
                LOGGER.error("async task execute failed e={}", var9);
                return null;
            }
        } else {
            throw new RuntimeException("async task is null");
        }
    }

    public static void main(String[] args) {
        AsyncTask task1 = new AsyncTask() {
            public Object run() {
                System.out.println(Thread.currentThread() + "---------");
                return null;
            }
        };
        AsyncTask task2 = new AsyncTask() {
            public Object run() {
                System.out.println(Thread.currentThread() + "==========");
                return null;
            }
        };
        List<AsyncTask> taskList = new ArrayList();
        taskList.add(task1);
        taskList.add(task2);
        runAll(taskList);
    }

    static {
        executor = new ThreadPoolExecutor(10, 20, 60L, TimeUnit.SECONDS, new SynchronousQueue());
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值