Spring boot多線(xiàn)程配置方法
本文實(shí)例為大家分享了Spring boot多線(xiàn)程配置的具體代碼,供大家參考,具體內(nèi)容如下
1、配置線(xiàn)程配置類(lèi)
package test;
import java.util.concurrent.Executor;
import org.springframework.aop.interceptor.AsyncUncaughtExceptionHandler;
import org.springframework.context.annotation.ComponentScan;
import org.springframework.context.annotation.Configuration;
import org.springframework.scheduling.annotation.AsyncConfigurer;
import org.springframework.scheduling.annotation.EnableAsync;
import org.springframework.scheduling.concurrent.ThreadPoolTaskExecutor;
@Configuration
@ComponentScan("test")
@EnableAsync
// 線(xiàn)程配置類(lèi)
public class AsyncTaskConfig implements AsyncConfigurer {
// ThredPoolTaskExcutor的處理流程
// 當(dāng)池子大小小于corePoolSize,就新建線(xiàn)程,并處理請(qǐng)求
// 當(dāng)池子大小等于corePoolSize,把請(qǐng)求放入workQueue中,池子里的空閑線(xiàn)程就去workQueue中取任務(wù)并處理
// 當(dāng)workQueue放不下任務(wù)時(shí),就新建線(xiàn)程入池,并處理請(qǐng)求,如果池子大小撐到了maximumPoolSize,就用RejectedExecutionHandler來(lái)做拒絕處理
// 當(dāng)池子的線(xiàn)程數(shù)大于corePoolSize時(shí),多余的線(xiàn)程會(huì)等待keepAliveTime長(zhǎng)時(shí)間,如果無(wú)請(qǐng)求可處理就自行銷(xiāo)毀
@Override
public Executor getAsyncExecutor() {
ThreadPoolTaskExecutor taskExecutor = new ThreadPoolTaskExecutor();
taskExecutor.setCorePoolSize(5);// 最小線(xiàn)程數(shù)
taskExecutor.setMaxPoolSize(10);// 最大線(xiàn)程數(shù)
taskExecutor.setQueueCapacity(25);// 等待隊(duì)列
taskExecutor.initialize();
return taskExecutor;
}
@Override
public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() {
return null;
}
}
2、定義線(xiàn)程執(zhí)行任務(wù)類(lèi)
package test;
import java.util.Random;
import java.util.concurrent.Future;
import org.springframework.scheduling.annotation.Async;
import org.springframework.scheduling.annotation.AsyncResult;
import org.springframework.stereotype.Service;
@Service
// 線(xiàn)程執(zhí)行任務(wù)類(lèi)
public class AsyncTaskService {
Random random = new Random();// 默認(rèn)構(gòu)造方法
@Async
// 表明是異步方法
// 無(wú)返回值
public void executeAsyncTask(Integer i) {
System.out.println("執(zhí)行異步任務(wù):" + i);
}
/**
* 異常調(diào)用返回Future
*
* @param i
* @return
* @throws InterruptedException
*/
@Async
public Future<String> asyncInvokeReturnFuture(int i) throws InterruptedException {
System.out.println("input is " + i);
Thread.sleep(1000 * random.nextInt(i));
Future<String> future = new AsyncResult<String>("success:" + i);// Future接收返回值,這里是String類(lèi)型,可以指明其他類(lèi)型
return future;
}
}
3、調(diào)用
package test;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.Future;
import org.springframework.context.annotation.AnnotationConfigApplicationContext;
import org.springframework.core.task.TaskRejectedException;
public class Application {
public static void main(String[] args) throws InterruptedException, ExecutionException {
// testVoid();
testReturn();
}
// 測(cè)試無(wú)返回結(jié)果
private static void testVoid() {
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(AsyncTaskConfig.class);
AsyncTaskService asyncTaskService = context.getBean(AsyncTaskService.class);
// 創(chuàng)建了20個(gè)線(xiàn)程
for (int i = 1; i <= 20; i++) {
asyncTaskService.executeAsyncTask(i);
}
context.close();
}
// 測(cè)試有返回結(jié)果
private static void testReturn() throws InterruptedException, ExecutionException {
AnnotationConfigApplicationContext context = new AnnotationConfigApplicationContext(AsyncTaskConfig.class);
AsyncTaskService asyncTaskService = context.getBean(AsyncTaskService.class);
List<Future<String>> lstFuture = new ArrayList<Future<String>>();// 存放所有的線(xiàn)程,用于獲取結(jié)果
// 創(chuàng)建100個(gè)線(xiàn)程
for (int i = 1; i <= 100; i++) {
while (true) {
try {
// 線(xiàn)程池超過(guò)最大線(xiàn)程數(shù)時(shí),會(huì)拋出TaskRejectedException,則等待1s,直到不拋出異常為止
Future<String> future = asyncTaskService.asyncInvokeReturnFuture(i);
lstFuture.add(future);
break;
} catch (TaskRejectedException e) {
System.out.println("線(xiàn)程池滿(mǎn),等待1S。");
Thread.sleep(1000);
}
}
}
// 獲取值。get是阻塞式,等待當(dāng)前線(xiàn)程完成才返回值
for (Future<String> future : lstFuture) {
System.out.println(future.get());
}
context.close();
}
}
maven配置
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance" xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>TestAysc</groupId>
<artifactId>TestAysc</artifactId>
<version>0.0.1-SNAPSHOT</version>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot</artifactId>
<version>1.5.6.RELEASE</version>
</dependency>
<dependency>
<groupId>org.springframework</groupId>
<artifactId>spring-aop</artifactId>
<version>4.3.10.RELEASE</version>
</dependency>
</dependencies>
</project>
結(jié)果展示:
1、無(wú)返回結(jié)果

2、有返回結(jié)果

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- Spring Boot中配置定時(shí)任務(wù)、線(xiàn)程池與多線(xiàn)程池執(zhí)行的方法
- 詳解SpringBoot 多線(xiàn)程處理任務(wù) 無(wú)法@Autowired注入bean問(wèn)題解決
- spring boot中多線(xiàn)程開(kāi)發(fā)的注意事項(xiàng)總結(jié)
- 解決SpringBoot項(xiàng)目使用多線(xiàn)程處理任務(wù)時(shí)無(wú)法通過(guò)@Autowired注入bean問(wèn)題
- 詳解Springboot對(duì)多線(xiàn)程的支持
- Spring Boot 配置和使用多線(xiàn)程池的實(shí)現(xiàn)
- SpringBoot 多任務(wù)并行+線(xiàn)程池處理的實(shí)現(xiàn)
- 詳解Spring-Boot中如何使用多線(xiàn)程處理任務(wù)
- Spring boot使用多線(xiàn)程過(guò)程步驟解析
相關(guān)文章
詳解Idea SpringBoot搭建SpringCloud的準(zhǔn)備工作(推薦)
這篇文章主要介紹了Idea SpringBoot搭建SpringCloud的準(zhǔn)備工作(推薦),本文通過(guò)圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-10-10
SpringBoot項(xiàng)目使用yml文件鏈接數(shù)據(jù)庫(kù)異常問(wèn)題解決方案
在使用SpringBoot時(shí),利用yml進(jìn)行數(shù)據(jù)庫(kù)連接配置需小心數(shù)據(jù)類(lèi)型區(qū)分,如果用戶(hù)名或密碼是數(shù)字,必須用雙引號(hào)包裹以識(shí)別為字符串,避免連接錯(cuò)誤,特殊字符密碼也應(yīng)用引號(hào)包裹2024-10-10
springboottest測(cè)試依賴(lài)和使用方式
這篇文章主要介紹了springboottest測(cè)試依賴(lài)和使用方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2022-03-03
SpringMVC實(shí)現(xiàn)參數(shù)校驗(yàn)配置方法
這篇文章主要介紹了SpringMVC實(shí)現(xiàn)參數(shù)校驗(yàn)的配置方式,Spring MVC會(huì)拋出MethodArgumentNotValidException異常,并將錯(cuò)誤信息綁定到相應(yīng)的字段上,感興趣的朋友跟隨小編一起看看吧2024-03-03
elasticsearch聚合查詢(xún)實(shí)踐示例
這篇文章主要為大家介紹了elasticsearch聚合查詢(xún)實(shí)踐示例,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-12-12
java實(shí)現(xiàn)給圖片加鋪滿(mǎn)的網(wǎng)格式文字水印
這篇文章主要給大家介紹了關(guān)于java實(shí)現(xiàn)給圖片加鋪滿(mǎn)的網(wǎng)格式文字水印的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2021-01-01
spring 自動(dòng)注入AutowiredAnnotationBeanPostProcessor源碼解析
這篇文章主要介紹了spring自動(dòng)注入AutowiredAnnotationBeanPostProcessor源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-03-03
java統(tǒng)計(jì)漢字字?jǐn)?shù)的方法示例
這篇文章主要介紹了java統(tǒng)計(jì)漢字字?jǐn)?shù)的方法,結(jié)合實(shí)例形式分析了java正則判定、字符串遍歷及統(tǒng)計(jì)相關(guān)操作技巧,需要的朋友可以參考下2017-05-05
解析Java實(shí)現(xiàn)設(shè)計(jì)模式六大原則之里氏替換原則
里氏替換原則是用來(lái)幫助我們?cè)诶^承關(guān)系中進(jìn)行父子類(lèi)的設(shè)計(jì)。它闡述了有關(guān)繼承的一些原則,也就是什么時(shí)候應(yīng)該使用繼承,什么時(shí)候不應(yīng)該使用繼承,以及其中蘊(yùn)含的原理。它是繼承復(fù)用的基礎(chǔ),反映了基類(lèi)與子類(lèi)之間的關(guān)系,是對(duì)開(kāi)閉原則的補(bǔ)充,對(duì)實(shí)現(xiàn)抽象化具體步驟的規(guī)范2021-06-06

