springboot在service的方法中使用多线程,非注解,无配置

优点:

1、不用使用注解@Async

2、灵活配置线程池数量

3、执行完所有线程后,再执行后续的代码或方法

核心方法:

public void doSomething3() {
        ExecutorService executor = Executors.newFixedThreadPool(20); //Runtime.getRuntime().availableProcessors()
        List<CompletableFuture<?>> futures = new ArrayList<>(); 
        for(int i=0 ; i<128; i++) {
            CompletableFuture<?> future = CompletableFuture.runAsync(() -> {
            	log.debug(Thread.currentThread().getName() + "运行...");
                try {
                    Thread.sleep(1000); // 模拟耗时操作
                } catch (InterruptedException e) {
                    Thread.currentThread().interrupt();
                }
            }, executor);  
            futures.add(future);  
        }  
        // 等待所有任务完成  
        CompletableFuture.allOf(futures.toArray(new CompletableFuture<?>[0])).join();
        // 关闭ExecutorService  
        executor.shutdown();  
        // 所有任务完成后执行的代码(如果需要)  
        // ...  
    }  

### Spring Boot配置线程池实现多线程处理 #### 使用`@Configuration`类定义线程池 Bean 为了在Spring Boot应用程序中配置自定义线程池,可以通过创建一个新的配置类并使用`@Bean`注解来声明一个`ThreadPoolTaskExecutor`类型的bean。这允许开发者指定诸如核心线程数、最大线程数等参数。 ```java import org.springframework.context.annotation.Bean; import org.springframework.context.annotation.Configuration; import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor; @Configuration public class ThreadPoolConfig { @Bean(name = "taskExecutor") public ThreadPoolTaskExecutor taskExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); // 设置核心线程数为CPU核数的两倍 int coreSize = Runtime.getRuntime().availableProcessors() * 2; // 设置最大线程数为CPU核数的四倍 int maxSize = Runtime.getRuntime().availableProcessors() * 4; executor.setCorePoolSize(coreSize); executor.setMaxPoolSize(maxSize); executor.setQueueCapacity(100); // 队列容量设为100 executor.setThreadNamePrefix("MyTask-"); // 线程名称前缀 // 初始化时启动最小数量的核心线程 executor.initialize(); return executor; } } ``` 上述代码片段展示了如何通过编程方式配置线程池[^3]。 #### 创建异步方法执行任务 为了让某个服务的方法能够被多个线程并发调用,可以在该方法上加上`@Async`注解,并确保已经启用了异步支持(即,在任意配置文件里添加`@EnableAsync`)。下面的例子说明了这一点: ```java import org.springframework.beans.factory.annotation.Autowired; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; @Service public class AsyncTaskService { private final ThreadPoolTaskExecutor taskExecutor; @Autowired public AsyncTaskService(ThreadPoolTaskExecutor taskExecutor) { this.taskExecutor = taskExecutor; } @Async("taskExecutor") // 指定使用线程池名 public void executeAsyncTask(int i){ System.out.println( Thread.currentThread().getName()+" is executing : "+i+" at time:"+System.currentTimeMillis()); } } ``` 这段程序实现了简单的后台任务调度功能,其中每个请求都会由不同的工作线程独立完成[^1]。 #### 测试异步任务的效果 最后一步是在控制器或者其他组件内测试这个新特性的工作情况。这里给出了一种可能的方式来进行验证: ```java @RestController @RequestMapping("/tasks") public class AsyncController { @Autowired private AsyncTaskService asyncTaskService; @GetMapping("/async/{count}") public String invokeTasks(@PathVariable Integer count) throws InterruptedException{ long start=System.currentTimeMillis(); for (int i = 0 ; i<count;i++){ asyncTaskService.executeAsyncTask(i); } while(System.currentTimeMillis()-start<5000){} //等待一段时间让所有任务结束 return "All tasks have been submitted!"; } } ``` 此段代码提供了一个HTTP端点用于触发一系列异步操作,并且会暂停主线程直到预计所有的子任务都已完成才返回响应给客户端[^2]。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值