ExecutorService實(shí)現(xiàn)獲取線程返回值
什么是ExecutorService?
ExecutorService是java.util.concurrent包中的一個(gè)線程池實(shí)現(xiàn)接口。其有兩個(gè)實(shí)現(xiàn)類:ThreadPoolExecutor 和 ScheduledThreadPoolExecutor。分別用來(lái)實(shí)現(xiàn)普通線程池和延遲任務(wù)線程池。普通線程池通過(guò)配置線程池大小,能有效管理線程的調(diào)度,在執(zhí)行大量異步線程時(shí)提高程序的性能。延遲任務(wù)線程池可控制在給定多長(zhǎng)的延遲后執(zhí)行線程。想要實(shí)現(xiàn)獲取線程的返回值,可以通過(guò)ThreadPoolExecutor及其子類管理線程。
實(shí)現(xiàn)帶返回值的Callable子類
創(chuàng)建一個(gè)線程類實(shí)現(xiàn)Callable接口,重寫call方法,其中call方法相當(dāng)于Thread子類中的run方法。其內(nèi)容為線程運(yùn)行時(shí)所執(zhí)行的業(yè)務(wù)。
ThreadWithCallable.java
package thread;
import java.util.concurrent.Callable;
/**
?* ?一個(gè)包含返回值的線程類
?* @author xiezd 2018-01-14 21:40
?*
?*/
public class ThreadWithCallback implements Callable{
? ? private int number;
? ? public ThreadWithCallback(int number){
? ? ? ? this.number = number;
? ? }
? ? //相當(dāng)于Thread的run方法
? ? @Override
? ? public Object call() throws Exception {
? ? ? ? long begin = System.currentTimeMillis();
? ? ? ? int index = (int)(Math.random() * 99999999);
? ? ? ? int result = number;
? ? ? ? //隨便寫的
? ? ? ? for (int i = 1; i < index; i++) {
? ? ? ? ? ? result = (result / i ) * index;
? ? ? ? }
? ? ? ? long end = System.currentTimeMillis();
? ? ? ? return "計(jì)算數(shù)值為" + number + "的線程,花費(fèi):" + (end - begin) + "毫秒。";
? ? }
}創(chuàng)建線程池測(cè)試
編寫一個(gè)測(cè)試類:
1.通過(guò)Excutors工廠類獲取一個(gè)固定大小的線程池對(duì)象。
2.調(diào)用線程池對(duì)象的submit方法,參數(shù)為一個(gè)線程對(duì)象,返回值為Future對(duì)象。
3.調(diào)用Future對(duì)象的get方法獲取線程返回值。
4.關(guān)閉線程池。
App.java
package thread;
import java.util.concurrent.ExecutionException;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
import java.util.concurrent.Future;
/**
?* @author xiezd 2018-01-14 21:49
?*/
public class App {
? ? public static void main(String[] args) {
? ? ? ? ExecutorService executors = Executors.newFixedThreadPool(10);
? ? ? ? try {
? ? ? ? ? ? /* 啟動(dòng)線程時(shí)會(huì)返回一個(gè)Future對(duì)象。
? ? ? ? ? ? ?* 可以通過(guò)future對(duì)象獲取現(xiàn)成的返回值。
? ? ? ? ? ? ?* 在執(zhí)行future.get()時(shí),主線程會(huì)堵塞,直至當(dāng)前future線程返回結(jié)果。
? ? ? ? ? ? ?*/
? ? ? ? ? ? Future future1 = executors.submit(new ThreadWithCallback(20));
? ? ? ? ? ? Future future2 = executors.submit(new ThreadWithCallback(30));
? ? ? ? ? ? System.out.println(future1.get());
? ? ? ? ? ? System.out.println(future2.get());
? ? ? ? } catch (InterruptedException e) {
? ? ? ? ? ? e.printStackTrace();
? ? ? ? } catch (ExecutionException e) {
? ? ? ? ? ? e.printStackTrace();
? ? ? ? }finally {
? ? ? ? ? ? executors.shutdown();
? ? ? ? }
? ? }
}注:在future調(diào)用get方法時(shí),主線程會(huì)阻塞(sè),直到該線程執(zhí)行完畢返回對(duì)象了只有才繼續(xù)運(yùn)行。
如果要執(zhí)行n個(gè)線程,可以把future放入Set集合中,在所有線程都啟動(dòng)完畢后,遍歷Set取出返回值。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
相關(guān)文章
Java中語(yǔ)音url轉(zhuǎn)換成InputStream的示例代碼
在Java中,可以使用java.net.URL和java.net.URLConnection類來(lái)將語(yǔ)音URL轉(zhuǎn)換為InputStream,本文通過(guò)示例代碼介紹Java中語(yǔ)音url轉(zhuǎn)換成InputStream的相關(guān)知識(shí),感興趣的朋友一起看看吧2024-01-01
jd-easyflow中inclusive的用法示例小結(jié)
文章介紹了在jd-easyflow中使用inclusive進(jìn)行條件分支配置的方法,當(dāng)conditionType設(shè)置為inclusive時(shí),所有條件分支都會(huì)被評(píng)估,而不僅僅是一個(gè)條件滿足就終止,本文給大家介紹的非常詳細(xì),感興趣的朋友跟隨小編一起看看吧2024-11-11
springboot IDEA啟動(dòng)兩個(gè)端口服務(wù)nginx負(fù)載過(guò)程
這篇文章主要介紹了springboot IDEA啟動(dòng)兩個(gè)端口服務(wù)nginx負(fù)載過(guò)程,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2025-03-03
java socket實(shí)現(xiàn)聊天室 java實(shí)現(xiàn)多人聊天功能
這篇文章主要為大家詳細(xì)介紹了java socket實(shí)現(xiàn)聊天室,java實(shí)現(xiàn)多人聊天功能,文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2018-07-07
springboot集成springsession如何實(shí)現(xiàn)分布式session共享
這篇文章主要介紹了springboot集成springsession如何實(shí)現(xiàn)分布式session共享問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2023-09-09
解決Feign配置RequestContextHolder.getRequestAttributes()為null的問(wèn)題
這篇文章主要介紹了解決Feign配置RequestContextHolder.getRequestAttributes()為null的問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-01-01
SpringCloud微服務(wù)網(wǎng)關(guān)限流方式
這篇文章主要介紹了SpringCloud微服務(wù)網(wǎng)關(guān)限流方式,具有很好的參考價(jià)值,希望對(duì)大家有所幫助,如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2024-08-08
SpringBoot3中數(shù)據(jù)庫(kù)集成實(shí)踐詳解
項(xiàng)目工程中,集成數(shù)據(jù)庫(kù)實(shí)現(xiàn)對(duì)數(shù)據(jù)的增曬改查管理,是最基礎(chǔ)的能力,所以下面小編就來(lái)和大家講講SpringBoot3如何實(shí)現(xiàn)數(shù)據(jù)庫(kù)集成,需要的可以參考下2023-08-08

