實例講解spring boot 多線程
Spring 通過任務執(zhí)行器(TaskExecutor)來實現(xiàn)多線程和并發(fā)編程。使用ThreadPoolTaskExecutor可實現(xiàn)一個基于線程池的TaskExecutor。而實際開發(fā)中任務一般是非阻塞的,即異步的,所有我們在配置類中通過@EnableAsync開啟對異步任務的支持,并通過在實際執(zhí)行的Bean的方法中使用@Async注解來聲明其是一個異步任務。
一、配置類
package com.cenobitor.taskxecutor.config;
import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.AsyncConfigurer;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
import java.util.concurrent.Executor;
@Configuration
@EnableAsync
public class TaskExecutorConfig implements AsyncConfigurer {
@Override
public Executor getAsyncExecutor() {
ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
taskExecutor.setCorePoolSize(5);
taskExecutor.setMaxPoolSize(10);
taskExecutor.setQueueCapacity(25);
taskExecutor.initialize();
return taskExecutor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return null;
}
}
1、利用@EnableAsync注解開啟異步任務支持
2、配置類實現(xiàn)AsyncConfigurer接口并重寫getAsyncExecutor方法,并返回一個ThreadPoolTaskExecutor,這樣我們就獲得了一個基于線程池TaskExecutor。
二、任務執(zhí)行類
package com.cenobitor.taskxecutor.taskservice;
import org.springframework.scheduling.annotation.Async;
import org.springframework.stereotype.Service;
@Service
public class AsyncTaskService {
@Async
public void excuteAsyncTask(Integer i){
System.out.println("異步執(zhí)行任務:"+i);
}
@Async
public void excuteAsyncTaskPlus(Integer i){
System.out.println("異步執(zhí)行任務+1:"+(i+1));
}
}
通過@Async注解表明該方法是異步方法,如果注解在類級別,則表明該類所有的方法都是異步方法,而這里的方法自動被注入使用ThreadPoolTaskExecutor作為TaskExecutor。
如果在異步方法所在類中調(diào)用異步方法,將會失效;
三、運行
package com.cenobitor.taskxecutor;
import com.cenobitor.taskxecutor.taskservice.AsyncTaskService;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
public class Main {
public static void main(String[] args) {
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(TaskxecutorApplication.class);
AsyncTaskService asyncTaskService = context.getBean(AsyncTaskService.class);
for (int i = 0; i < 10; i++) {
asyncTaskService.excuteAsyncTask(i);
asyncTaskService.excuteAsyncTaskPlus(i);
}
context.close();
}
}
運行結果:
異步執(zhí)行任務:0
異步執(zhí)行任務+1:1
異步執(zhí)行任務:1
異步執(zhí)行任務+1:2
異步執(zhí)行任務:2
異步執(zhí)行任務:3
異步執(zhí)行任務:5
異步執(zhí)行任務+1:6
異步執(zhí)行任務:6
異步執(zhí)行任務+1:7
異步執(zhí)行任務:7
異步執(zhí)行任務+1:8
異步執(zhí)行任務:8
異步執(zhí)行任務+1:9
異步執(zhí)行任務:9
異步執(zhí)行任務+1:10
異步執(zhí)行任務+1:3
異步執(zhí)行任務:4
異步執(zhí)行任務+1:5
異步執(zhí)行任務+1:4
注:摘抄自《JavaEE開發(fā)的顛覆者SpringBoot 實戰(zhàn)》。
以上就是實例講解spring boot 多線程的詳細內(nèi)容,更多關于spring boot 多線程的資料請關注腳本之家其它相關文章!
- Spring Boot如何優(yōu)雅的使用多線程實例詳解
- Spring Boot定時+多線程執(zhí)行過程解析
- Spring boot如何通過@Scheduled實現(xiàn)定時任務及多線程配置
- Spring Boot中配置定時任務、線程池與多線程池執(zhí)行的方法
- spring-boot 多線程并發(fā)定時任務的解決方案
- 詳解SpringBoot 多線程處理任務 無法@Autowired注入bean問題解決
- spring boot中多線程開發(fā)的注意事項總結
- 解決SpringBoot項目使用多線程處理任務時無法通過@Autowired注入bean問題
- 詳解Springboot對多線程的支持
相關文章
SpringCloud?Gateway中GatewayFilterChain執(zhí)行流程詳解
Spring?Cloud?Gateway旨在為微服務架構提供一種簡單有效的、統(tǒng)一的?API?路由管理方式。Spring?Cloud?Gateway?作為?Spring?Cloud?生態(tài)系中的網(wǎng)關,它不僅提供統(tǒng)一的路由方式,并且基于?Filter?鏈的方式提供了網(wǎng)關基本的功能,例如:安全、監(jiān)控/埋點和限流等2022-10-10
Maven方式構建SpringBoot項目的實現(xiàn)步驟(圖文)
Maven是一個強大的項目管理工具,可以幫助您輕松地構建和管理Spring Boot應用程序,本文主要介紹了Maven方式構建SpringBoot項目的實現(xiàn)步驟,具有一定的參考價值,感興趣的可以了解一下2023-09-09
RxJava的消息發(fā)送和線程切換實現(xiàn)原理
這篇文章主要介紹了RxJava的消息發(fā)送和線程切換實現(xiàn)原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11

