摘要:對(duì)多線程的支持詳解這兩天看阿里的開發(fā)手冊(cè),到多線程的時(shí)候說永遠(yuǎn)不要用這種方式來使用多線程。在使用線程池的大多數(shù)情況下都是異步非阻塞的。二配置類配置類代碼如下下午解讀利用來開啟對(duì)于異步任務(wù)的支持配置類實(shí)現(xiàn)接口,返回一個(gè)線程池對(duì)象。
Springboot對(duì)多線程的支持詳解
這兩天看阿里的JAVA開發(fā)手冊(cè),到多線程的時(shí)候說永遠(yuǎn)不要用 new Thread()這種方式來使用多線程。確實(shí)是這樣的,我一直在用線程池,到了springboot才發(fā)現(xiàn)他已經(jīng)給我們提供了很方便的線程池機(jī)制。一、介紹
本博客代碼托管在github上https://github.com/gxz0422042...
Spring是通過任務(wù)執(zhí)行器(TaskExecutor)來實(shí)現(xiàn)多線程和并發(fā)編程,使用ThreadPoolTaskExecutor來創(chuàng)建一個(gè)基于線城池的TaskExecutor。在使用線程池的大多數(shù)情況下都是異步非阻塞的。我們配置注解@EnableAsync可以開啟異步任務(wù)。然后在實(shí)際執(zhí)行的方法上配置注解@Async上聲明是異步任務(wù)。
二、配置類配置類代碼如下:
package com.spartajet.springbootlearn.thread; 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; /** * @description * @create 2017-02-22 下午11:53 * @email [email protected] */ @Configuration @EnableAsync public class ThreadConfig implements AsyncConfigurer { /** * The {@link Executor} instance to be used when processing async * method invocations. */ @Override public Executor getAsyncExecutor() { ThreadPoolTaskExecutor executor = new ThreadPoolTaskExecutor(); executor.setCorePoolSize(5); executor.setMaxPoolSize(15); executor.setQueueCapacity(25); executor.initialize(); return executor; } /** * The {@link AsyncUncaughtExceptionHandler} instance to be used * when an exception is thrown during an asynchronous method execution * with {@code void} return type. */ @Override public AsyncUncaughtExceptionHandler getAsyncUncaughtExceptionHandler() { return null; } }
解讀:
利用EnableAsync來開啟Springboot對(duì)于異步任務(wù)的支持
配置類實(shí)現(xiàn)接口AsyncConfigurator,返回一個(gè)ThreadPoolTaskExecutor線程池對(duì)象。
三、任務(wù)執(zhí)行任務(wù)執(zhí)行代碼:
package com.spartajet.springbootlearn.thread; import org.springframework.scheduling.annotation.Async; import org.springframework.stereotype.Service; /** * @description * @create 2017-02-23 上午12:00 * @email [email protected] */ @Service public class AsyncTaskService { @Async public void executeAsyncTask(int i) { System.out.println("線程" + Thread.currentThread().getName() + " 執(zhí)行異步任務(wù):" + i); } }
代碼解讀:
通過@Async注解表明該方法是異步方法,如果注解在類上,那表明這個(gè)類里面的所有方法都是異步的。
四、測(cè)試代碼package com.spartajet.springbootlearn; import com.spartajet.springbootlearn.thread.AsyncTaskService; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.test.context.junit4.SpringRunner; @RunWith (SpringRunner.class) @SpringBootTest public class SpringbootLearnApplicationTests { @Autowired private AsyncTaskService asyncTaskService; @Test public void contextLoads() { } @Test public void threadTest() { for (int i = 0; i < 20; i++) { asyncTaskService.executeAsyncTask(i); } } }
測(cè)試結(jié)果:
線程ThreadPoolTaskExecutor-4 執(zhí)行異步任務(wù):3 線程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):1 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):0 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):7 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):8 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):9 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):10 線程ThreadPoolTaskExecutor-5 執(zhí)行異步任務(wù):4 線程ThreadPoolTaskExecutor-3 執(zhí)行異步任務(wù):2 線程ThreadPoolTaskExecutor-5 執(zhí)行異步任務(wù):12 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):11 線程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):6 線程ThreadPoolTaskExecutor-4 執(zhí)行異步任務(wù):5 線程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):16 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):15 線程ThreadPoolTaskExecutor-5 執(zhí)行異步任務(wù):14 線程ThreadPoolTaskExecutor-3 執(zhí)行異步任務(wù):13 線程ThreadPoolTaskExecutor-1 執(zhí)行異步任務(wù):19 線程ThreadPoolTaskExecutor-2 執(zhí)行異步任務(wù):18 線程ThreadPoolTaskExecutor-4 執(zhí)行異步任務(wù):17
文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/76485.html
摘要:線程切換效率低下單機(jī)核數(shù)固定,線程爆炸之后操作系統(tǒng)頻繁進(jìn)行線程切換,應(yīng)用性能急劇下降。線程切換效率低下由于模型中線程數(shù)量大大降低,線程切換效率因此也大幅度提高。將兩個(gè)線程優(yōu)雅地關(guān)閉。創(chuàng)建管道的子處理器,用于處理。 Netty+SpringBoot+FastDFS+Html5實(shí)現(xiàn)聊天App,項(xiàng)目介紹:https://segmentfault.com/a/11... Netty+Sprin...
摘要:線程切換效率低下單機(jī)核數(shù)固定,線程爆炸之后操作系統(tǒng)頻繁進(jìn)行線程切換,應(yīng)用性能急劇下降。線程切換效率低下由于模型中線程數(shù)量大大降低,線程切換效率因此也大幅度提高。將兩個(gè)線程優(yōu)雅地關(guān)閉。創(chuàng)建管道的子處理器,用于處理。 Netty+SpringBoot+FastDFS+Html5實(shí)現(xiàn)聊天App,項(xiàng)目介紹:https://segmentfault.com/a/11... Netty+Sprin...
摘要:多線程編程這篇文章分析了多線程的優(yōu)缺點(diǎn),如何創(chuàng)建多線程,分享了線程安全和線程通信線程池等等一些知識(shí)。 中間件技術(shù)入門教程 中間件技術(shù)入門教程,本博客介紹了 ESB、MQ、JMS 的一些知識(shí)... SpringBoot 多數(shù)據(jù)源 SpringBoot 使用主從數(shù)據(jù)源 簡易的后臺(tái)管理權(quán)限設(shè)計(jì) 從零開始搭建自己權(quán)限管理框架 Docker 多步構(gòu)建更小的 Java 鏡像 Docker Jav...
摘要:前提好幾周沒更新博客了,對(duì)不斷支持我博客的童鞋們說聲抱歉了。熟悉我的人都知道我寫博客的時(shí)間比較早,而且堅(jiān)持的時(shí)間也比較久,一直到現(xiàn)在也是一直保持著更新狀態(tài)。 showImg(https://segmentfault.com/img/remote/1460000014076586?w=1920&h=1080); 前提 好幾周沒更新博客了,對(duì)不斷支持我博客的童鞋們說聲:抱歉了!。自己這段時(shí)...
閱讀 3550·2023-04-26 00:16
閱讀 1367·2021-11-25 09:43
閱讀 3836·2021-11-23 09:51
閱讀 2975·2021-09-24 09:55
閱讀 726·2021-09-22 15:45
閱讀 1402·2021-07-30 15:30
閱讀 3071·2019-08-30 14:04
閱讀 2253·2019-08-26 13:46