使用Callable多线程实现对list数据的处理

1.简单介绍通过实现Callable接口创建线程
与Runable相比的区别在于:runable没有返回值,
Callable可以用Future<数据类型>接收返回值

class TaskWithResult implements Callable<String> {   //创建一个线程
    private int id;
    public TaskWithResult(int id) {
        this.id=id;
    }
    
    @Override
    public String call() throws Exception {
        return "result of TaskWithResult "+id;
    }
}
package com.test;

import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.Callable;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;

public class CallableTest {
    public static void main(String[] args) {
        ExecutorService exec=Executors.newCachedThreadPool();  //创建线程池
        List<Future<String>> results=new ArrayList<Future<String>>();  //定义接收返回值的list
        
        for(int i=0;i<5;i++) {
            results.add(exec.submit(new TaskWithResult(i))); //执行线程并添加返回值
        }
        
        for(Future<String> fs :results) {   //打印返回值
            try {
                System.out.println(fs.get());
            } catch (InterruptedException e) {
                e.printStackTrace();
            } catch (ExecutionException e) {
                e.printStackTrace();
            }
        }
    }
}

2.利用多线程处理list中的数据

public class ThreadList {
 
	public static void main(String[] args) throws InterruptedException, ExecutionException {
		List<String> list = new ArrayList<>(); //造list数据
		for(int i=0;i<5300;i++){
			list.add(""+i);
		}
		
		int threadSize = 500;//每500条数据开启一个线程
		int remainder = list.size()%threadSize;  //取余
		int threadNum  = 0; //线程数
		if(remainder == 0){ //能整除500
			threadNum  = list.size()/threadSize;
		} else {  //不能整除线程数要加1
			threadNum  = list.size()/threadSize + 1;
		}
		
		ExecutorService eService = Executors.newFixedThreadPool(threadNum ); //创建一个线程池
		List<Callable<String>> cList = new ArrayList<>();  //定义添加线程的集合
		Callable<String> task = null;  //创建单个线程
		List<String> sList = null;
		
		for(int i=0;i<threadNum;i++){  //根据线程数去取数据和创建线程
		
			if(i == threadNum - 1){
				sList = list.subList(i*threadSize, list.size());
			} else {
				sList = list.subList(i*threadSize, (i+1)*threadSize);
			}
			
			final List<String> nowList = sList;
			//创建单个线程
			task = new Callable<String>() {
				@Override
				public String call() throws Exception {
					StringBuffer sb = new StringBuffer();
					for(int j=0;j<nowList.size();j++){
						sb.append(""+nowList.get(j));
					}
					return sb.toString();
				}
			};
			cList.add(task); //添加线程
		}
		List<Future<String>> results = eService.invokeAll(cList); //执行所有创建的线程,并获取返回值(会把所有线程的返回值都返回)

		for(Future<String> str:results){  //打印返回值
			System.out.println(str.get());
		}
		eService.shutdown();
	}
  • 1
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 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、付费专栏及课程。

余额充值