真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

java創(chuàng)建線程池代碼 java創(chuàng)建線程池實現(xiàn)方式

java 定義一個線程池 循環(huán)遍歷list,進(jìn)行讀寫操作

import?java.util.List;

創(chuàng)新互聯(lián)長期為上千客戶提供的網(wǎng)站建設(shè)服務(wù),團(tuán)隊從業(yè)經(jīng)驗10年,關(guān)注不同地域、不同群體,并針對不同對象提供差異化的產(chǎn)品和服務(wù);打造開放共贏平臺,與合作伙伴共同營造健康的互聯(lián)網(wǎng)生態(tài)環(huán)境。為中牟企業(yè)提供專業(yè)的成都做網(wǎng)站、網(wǎng)站制作,中牟網(wǎng)站改版等技術(shù)服務(wù)。擁有10年豐富建站經(jīng)驗和眾多成功案例,為您定制開發(fā)。

import?java.util.concurrent.Callable;

import?java.util.concurrent.ExecutionException;

import?java.util.concurrent.ExecutorService;

import?java.util.concurrent.Executors;

import?java.util.concurrent.Future;

/**

*?并發(fā)處理器

*?適用于如下場景(舉例):

*?一個任務(wù)隊列,?有150個任務(wù)需要并發(fā)處理,使用此對象,可以每次并發(fā)執(zhí)行20次(可設(shè)置),則總共串行執(zhí)行8次并發(fā),可獲取執(zhí)行結(jié)果

*

*?@param?T?類型T限制為任務(wù)Callable使用的數(shù)據(jù)對象和返回結(jié)果的數(shù)據(jù)對象為同一個bean

*/

public?class?ConcurrentExcutorT

{

/**?非空,所有任務(wù)數(shù)組?*/

private?CallableT[]?tasks;

/**?非空,每次并發(fā)需要處理的任務(wù)數(shù)?*/

private?int?numb;

/**?可選,存放返回結(jié)果,這里有個限制,泛型T必須為Callable返回的類型T?*/

private?ListT?result;

/**

*?無參構(gòu)造

*/

public?ConcurrentExcutor()

{

super();

}

/**

*?不需要返回結(jié)果的任務(wù)用此創(chuàng)建對象

*?@param?tasks

*?@param?numb

*/

public?ConcurrentExcutor(CallableT[]?tasks,?int?numb)

{

super();

this.tasks?=?tasks;

this.numb?=?numb;

}

/**

*?需要結(jié)果集用此方法創(chuàng)建對象

*?@param?tasks

*?@param?numb

*?@param?result

*/

public?ConcurrentExcutor(CallableT[]?tasks,?int?numb,?ListT?result)

{

super();

this.tasks?=?tasks;

this.numb?=?numb;

this.result?=?result;

}

public?void?excute()

{

//?參數(shù)校驗

if(tasks?==?null?||?numb??1)

{

return;

}

//?待處理的任務(wù)數(shù)

int?num?=?tasks.length;

if(num?==?0)

{

return;

}

//?第一層循環(huán),每numb條數(shù)據(jù)作為一次并發(fā)

for(int?i=0;?i(int)Math.floor(num/numb)?+?1;?i++)

{

//?用于記錄此次numb條任務(wù)的處理結(jié)果

Future[]?futureArray;

if(numb??num)

{

futureArray?=?new?Future[num];

}

else

{

futureArray?=?new?Future[numb];

}

//?創(chuàng)建線程容器

ExecutorService?es?=?Executors.newCachedThreadPool();

//?第二層循環(huán),針對這numb條數(shù)據(jù)進(jìn)行處理

for(int?j=i*numb;?j(i+1)*numb;?j++)

{

//?如果超出數(shù)組長度,退出循環(huán)

if(j?+?1??num)

{

break;

}

//?執(zhí)行任務(wù),并設(shè)置Future到數(shù)組中

futureArray[j%numb]?=?es.submit(tasks[j]);

}

//?將結(jié)果放入result中

if?(result?!=?null)

{

for?(int?j?=?0;?j??futureArray.length;?j++)

{

try

{

if(futureArray[j]?!=?null)

{

Object?o?=?futureArray[j].get();

result.add((T)o);

}

}

catch?(InterruptedException?e)

{

System.out.println("處理Future時發(fā)生InterruptedException異常,目標(biāo)Future為:?"?+?futureArray[j].toString());

e.printStackTrace();

}

catch?(ExecutionException?e)

{

System.out.println("處理Future時發(fā)生ExecutionException異常,目標(biāo)Future為:?"?+?futureArray[j].toString());

e.printStackTrace();

}

}

}

es.shutdown();

}

}

java中ExecutorService的線程池如何暫停任務(wù)和繼續(xù)任務(wù)? 有這樣的函數(shù)嗎?

接口 java.util.concurrent.ExecutorService 表述了異步執(zhí)行的機(jī)制,并且可以讓任務(wù)在后臺執(zhí)行。一個 ExecutorService 實例因此特別像一個線程池。事實上,在 java.util.concurrent 包中的 ExecutorService 的實現(xiàn)就是一個線程池的實現(xiàn)。

這里有一個簡單的使用Java 實現(xiàn)的 ExectorService 樣例:

使用 newFixedThreadPool() 工廠方法創(chuàng)建一個 ExecutorService ,上述代碼創(chuàng)建了一個可以容納10個線程任務(wù)的線程池。其次,向 execute() 方法中傳遞一個異步的 Runnable 接口的實現(xiàn),這樣做會讓 ExecutorService 中的某個線程執(zhí)行這個 Runnable 線程。

【Java基礎(chǔ)】線程池的原理是什么?

什么是線程池?

總歸為:池化技術(shù) ---》數(shù)據(jù)庫連接池 緩存架構(gòu) 緩存池 線程池 內(nèi)存池,連接池,這種思想演變成緩存架構(gòu)技術(shù)--- JDK設(shè)計思想有千絲萬縷的聯(lián)系

首先我們從最核心的ThreadPoolExecutor類中的方法講起,然后再講述它的實現(xiàn)原理,接著給出了它的使用示例,最后討論了一下如何合理配置線程池的大小。

Java 中的 ThreadPoolExecutor 類

java.uitl.concurrent.ThreadPoolExecutor 類是線程池中最核心的一個類,因此如果要透徹地了解Java 中的線程池,必須先了解這個類。下面我們來看一下 ThreadPoolExecutor 類的具體實現(xiàn)源碼。

在 ThreadPoolExecutor 類中提供了四個構(gòu)造方法:

從上面的代碼可以得知,ThreadPoolExecutor 繼承了 AbstractExecutorService 類,并提供了四個構(gòu)造器,事實上,通過觀察每個構(gòu)造器的源碼具體實現(xiàn),發(fā)現(xiàn)前面三個構(gòu)造器都是調(diào)用的第四個構(gòu)造器進(jìn)行的初始化工作。

下面解釋下一下構(gòu)造器中各個參數(shù)的含義:

corePoolSize:核心池的大小,這個參數(shù)跟后面講述的線程池的實現(xiàn)原理有非常大的關(guān)系。在創(chuàng)建了線程池后,默認(rèn)情況下,線程池中并沒有任何線程,而是等待有任務(wù)到來才創(chuàng)建線程去執(zhí)行任務(wù),除非調(diào)用了prestartAllCoreThreads() 或者 prestartCoreThread()方法,從這 2 個方法的名字就可以看出,是預(yù)創(chuàng)建線程的意思,即在沒有任務(wù)到來之前就創(chuàng)建 corePoolSize 個線程或者一個線程。默認(rèn)情況下,在創(chuàng)建了線程池后,線程池中的線程數(shù)為0,當(dāng)有任務(wù)來之后,就會創(chuàng)建一個線程去執(zhí)行任務(wù),當(dāng)線程池中的線程數(shù)目達(dá)到 corePoolSize 后,就會把到達(dá)的任務(wù)放到緩存隊列當(dāng)中;

maximumPoolSize:線程池最大線程數(shù),這個參數(shù)也是一個非常重要的參數(shù),它表示在線程池中最多能創(chuàng)建多少個線程;

keepAliveTime:表示線程沒有任務(wù)執(zhí)行時最多保持多久時間會終止。默認(rèn)情況下,只有當(dāng)線程池中的線程數(shù)大于 corePoolSize 時,keepAliveTime 才會起作用,直到線程池中的線程數(shù)不大于 corePoolSize,即當(dāng)線程池中的線程數(shù)大于 corePoolSize 時,如果一個線程空閑的時間達(dá)到 keepAliveTime,則會終止,直到線程池中的線程數(shù)不超過 corePoolSize。但是如果調(diào)用了 allowCoreThreadTimeOut(boolean) 方法,在線程池中的線程數(shù)不大于 corePoolSize 時,keepAliveTime 參數(shù)也會起作用,直到線程池中的線程數(shù)為0;

unit:參數(shù) keepAliveTime 的時間單位,有 7 種取值,在 TimeUnit 類中有 7 種靜態(tài)屬性:

workQueue:一個阻塞隊列,用來存儲等待執(zhí)行的任務(wù),這個參數(shù)的選擇也很重要,會對線程池的運(yùn)行過程產(chǎn)生重大影響,一般來說,這里的阻塞隊列有以下幾種選擇:

ArrayBlockingQueue 和 PriorityBlockingQueue 使用較少,一般使用 LinkedBlockingQueue 和 Synchronous。線程池的排隊策略與 BlockingQueue 有關(guān)。

threadFactory:線程工廠,主要用來創(chuàng)建線程;

handler:表示當(dāng)拒絕處理任務(wù)時的策略,有以下四種取值:

具體參數(shù)的配置與線程池的關(guān)系將在下一節(jié)講述。

從上面給出的 ThreadPoolExecutor 類的代碼可以知道,ThreadPoolExecutor 繼承了AbstractExecutorService,我們來看一下 AbstractExecutorService 的實現(xiàn):

AbstractExecutorService 是一個抽象類,它實現(xiàn)了 ExecutorService 接口。

我們接著看 ExecutorService 接口的實現(xiàn):

而 ExecutorService 又是繼承了 Executor 接口,我們看一下 Executor 接口的實現(xiàn):


網(wǎng)站標(biāo)題:java創(chuàng)建線程池代碼 java創(chuàng)建線程池實現(xiàn)方式
鏈接URL:http://weahome.cn/article/ddceheg.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部