Callable多线程处理不同的List数据之后返回List

场景:

有两个比较耗时的计算操作需要连接mongodb,同步执行可能需要7s,异步执行之后需要4s

代码

package callable_demo;

import com.alibaba.fastjson.JSONObject;
import org.omg.CORBA.TIMEOUT;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.FutureTask;
import java.util.concurrent.TimeUnit;

/**
 * 多线程中,第三种获得多线程方式
 *
 * @author dlf
 * @date 2021/4/18 23:52
 */
public class CallableDemo {
    public static void main(String[] args) throws ExecutionException, InterruptedException {

        //无返回值线程的使用
        new Thread(new MyThread(), "AAA").start();

        //有返回值的使用
        FutureTask futureTask = new FutureTask(new MyThread2(2));
        Thread thread = new Thread(futureTask, "BBB");
        thread.start();
        //  多个线程去争抢同一个FutureTask 只被执行一次
        new Thread(futureTask,"CCC").start();

        //要求获得Callable线程的计算结果,如果没有计算完成就要求去强求,会导致阻塞,直到计算完成
        //System.out.println("######result"+futureTask.get());
        //  关于优化  带有返回值的线程还没有算完的情况下的处理 类似自旋锁的思想
        while (!futureTask.isDone()){

        }

        System.out.println();

        System.out.println("######result"+futureTask.get());


        FutureTask futureTaskMockName = new FutureTask(new MockName("张三"));
        Thread threadMockName = new Thread(futureTaskMockName,"futureTaskMockName");
        threadMockName.start();


        FutureTask futureTaskMockAddress = new FutureTask(new mockAddressCallable("张家屯"));
        Thread threadMockAddress = new Thread(futureTaskMockAddress,"futureTaskMockAddress");
        threadMockAddress.start();


    /*   while (!futureTaskMockName.isDone()){

       }*/

        System.err.println("futureTaskMockName:"+futureTaskMockName.get());



     /*  while (!futureTaskMockAddress.isDone()){
       }*/

        System.err.println("futureTaskMockAddress:"+futureTaskMockAddress.get());



        System.err.println("所有线程执行完毕!");


        System.out.println("嘿嘿嘿");
    }
}

/**
 * 无返回值线程的使用
 */
class MyThread implements Runnable {

    @Override
    public void run() {

    }
}

/**
 * 有返回值的线程使用
 */
class MyThread2 implements Callable<Integer> {
    private Integer num;

    public MyThread2(Integer i) {
        this.num = i;
    }

    @Override
    public Integer call() throws Exception {

        try{
            TimeUnit.SECONDS.sleep(2);
        }catch (Exception e){
            e.printStackTrace();
        }
        System.out.println(Thread.currentThread().getName()+"\t come in =====");
        return num;
    }
}


class MockName implements Callable<List<JSONObject>> {

    private final String name;

    public MockName(String name) {
        this.name = name;
    }


    @Override
    public List<JSONObject> call() throws Exception {
        System.err.println(Thread.currentThread().getName()+"\t come in =====");

        List<JSONObject> result = new ArrayList<>();
        for (int i = 0; i < 500; i++) {
            JSONObject json = new JSONObject();
            json.put("name", name);
            json.put("age", ++i);
            result.add(json);
        }
        return result;
    }


}


class mockAddressCallable implements Callable<List<JSONObject>> {

    private final String address;

    public mockAddressCallable(String address) {
        this.address = address;
    }

    /**
     * Computes a result, or throws an exception if unable to do so.
     *
     * @return computed result
     * @throws Exception if unable to compute a result
     */
    @Override
    public List<JSONObject> call() throws Exception {
        return mockAddress(address);
    }

    /**
     * 模拟生成地址信息数据
     *
     * @return
     */
    List<JSONObject> mockAddress(String address) {
        List<JSONObject> result = new ArrayList<>();
        for (int i = 0; i < 500; i++) {
            JSONObject json = new JSONObject();
            json.fluentPut("name", "张山");
            json.fluentPut("address", address + (++i) + "号胡同");
            result.add(json);
        }
        return result;
    }
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Spring Boot中,可以使用Java多线程技术来处理数据。以下是一些示例: 1. 使用Java Executor框架执行任务 Java Executor框架提供了一种方便的方式来管理多线程任务。可以在Spring Boot应用程序中使用Executor框架来执行并发任务。可以使用线程池来管理线程,并且可以使用Callable或Runnable接口来定义任务。以下是一个示例: ```java @Service public class MyService { @Autowired private ThreadPoolTaskExecutor taskExecutor; public void processData(List<Data> dataList) { for (Data data : dataList) { taskExecutor.execute(() -> { // 处理数据 }); } } } ``` 在上面的代码中,使用Spring Boot的ThreadPoolTaskExecutor来管理线程池,然后使用execute方法来提交任务。 2. 使用Java CompletableFuture API执行异步任务 Java CompletableFuture API提供了一种方便的方式来执行异步任务。可以在Spring Boot应用程序中使用CompletableFuture来执行并发任务。以下是一个示例: ```java @Service public class MyService { public void processData(List<Data> dataList) { List<CompletableFuture<Void>> futures = new ArrayList<>(); for (Data data : dataList) { CompletableFuture<Void> future = CompletableFuture.runAsync(() -> { // 处理数据 }); futures.add(future); } CompletableFuture.allOf(futures.toArray(new CompletableFuture[futures.size()])).join(); } } ``` 在上面的代码中,使用CompletableFuture.runAsync方法来提交任务,并且使用CompletableFuture.allOf方法来等待所有任务完成。 3. 使用Spring Boot的@Async注解执行异步任务 Spring Boot提供了一个@Async注解,可以使用它来执行异步任务。可以在Spring Boot应用程序中使用@Async注解来执行并发任务。以下是一个示例: ```java @Service public class MyService { @Async public void processData(List<Data> dataList) { for (Data data : dataList) { // 处理数据 } } } ``` 在上面的代码中,使用@Async注解来标记方法,表示该方法是一个异步方法。Spring Boot会自动创建一个线程池来执行该方法,并且可以使用Future接口来获取异步方法的返回值。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值