實例講解spring boot 多線程
Spring 通過任務(wù)執(zhí)行器(TaskExecutor)來實現(xiàn)多線程和并發(fā)編程。使用ThreadPoolTaskExecutor可實現(xiàn)一個基于線程池的TaskExecutor。而實際開發(fā)中任務(wù)一般是非阻塞的,即異步的,所有我們在配置類中通過@EnableAsync開啟對異步任務(wù)的支持,并通過在實際執(zhí)行的Bean的方法中使用@Async注解來聲明其是一個異步任務(wù)。
一、配置類
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注解開啟異步任務(wù)支持
2、配置類實現(xiàn)AsyncConfigurer接口并重寫getAsyncExecutor方法,并返回一個ThreadPoolTaskExecutor,這樣我們就獲得了一個基于線程池TaskExecutor。
二、任務(wù)執(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í)行任務(wù):"+i); } @Async public void excuteAsyncTaskPlus(Integer i){ System.out.println("異步執(zhí)行任務(wù)+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(); } }
運行結(jié)果:
異步執(zhí)行任務(wù):0
異步執(zhí)行任務(wù)+1:1
異步執(zhí)行任務(wù):1
異步執(zhí)行任務(wù)+1:2
異步執(zhí)行任務(wù):2
異步執(zhí)行任務(wù):3
異步執(zhí)行任務(wù):5
異步執(zhí)行任務(wù)+1:6
異步執(zhí)行任務(wù):6
異步執(zhí)行任務(wù)+1:7
異步執(zhí)行任務(wù):7
異步執(zhí)行任務(wù)+1:8
異步執(zhí)行任務(wù):8
異步執(zhí)行任務(wù)+1:9
異步執(zhí)行任務(wù):9
異步執(zhí)行任務(wù)+1:10
異步執(zhí)行任務(wù)+1:3
異步執(zhí)行任務(wù):4
異步執(zhí)行任務(wù)+1:5
異步執(zhí)行任務(wù)+1:4
注:摘抄自《JavaEE開發(fā)的顛覆者SpringBoot 實戰(zhàn)》。
以上就是實例講解spring boot 多線程的詳細內(nèi)容,更多關(guān)于spring boot 多線程的資料請關(guān)注腳本之家其它相關(guān)文章!
- Spring Boot如何優(yōu)雅的使用多線程實例詳解
- Spring Boot定時+多線程執(zhí)行過程解析
- Spring boot如何通過@Scheduled實現(xiàn)定時任務(wù)及多線程配置
- Spring Boot中配置定時任務(wù)、線程池與多線程池執(zhí)行的方法
- spring-boot 多線程并發(fā)定時任務(wù)的解決方案
- 詳解SpringBoot 多線程處理任務(wù) 無法@Autowired注入bean問題解決
- spring boot中多線程開發(fā)的注意事項總結(jié)
- 解決SpringBoot項目使用多線程處理任務(wù)時無法通過@Autowired注入bean問題
- 詳解Springboot對多線程的支持
相關(guān)文章
SpringCloud?Gateway中GatewayFilterChain執(zhí)行流程詳解
Spring?Cloud?Gateway旨在為微服務(wù)架構(gòu)提供一種簡單有效的、統(tǒng)一的?API?路由管理方式。Spring?Cloud?Gateway?作為?Spring?Cloud?生態(tài)系中的網(wǎng)關(guān),它不僅提供統(tǒng)一的路由方式,并且基于?Filter?鏈的方式提供了網(wǎng)關(guān)基本的功能,例如:安全、監(jiān)控/埋點和限流等2022-10-10Maven方式構(gòu)建SpringBoot項目的實現(xiàn)步驟(圖文)
Maven是一個強大的項目管理工具,可以幫助您輕松地構(gòu)建和管理Spring Boot應(yīng)用程序,本文主要介紹了Maven方式構(gòu)建SpringBoot項目的實現(xiàn)步驟,具有一定的參考價值,感興趣的可以了解一下2023-09-09RxJava的消息發(fā)送和線程切換實現(xiàn)原理
這篇文章主要介紹了RxJava的消息發(fā)送和線程切換實現(xiàn)原理,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2018-11-11