亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

java線程池工作隊(duì)列飽和策略代碼示例

 更新時(shí)間:2017年11月23日 11:00:22   作者:lixwcqs  
這篇文章主要介紹了java線程池工作隊(duì)列飽和策略代碼示例,涉及線程池的簡單介紹,工作隊(duì)列飽和策略的分析及代碼示例,具有一定參考價(jià)值,需要的朋友可以了解下。

線程池(Thread Pool) 是并行執(zhí)行任務(wù)收集的實(shí)用工具。隨著 CPU 引入適合于應(yīng)用程序并行化的多核體系結(jié)構(gòu),線程池的作用正日益顯現(xiàn)。通過 ThreadPoolExecutor類及其他輔助類,Java 5 引入了這一框架,作為新的并發(fā)支持部分。

ThreadPoolExecutor框架靈活且功能強(qiáng)大,它支持特定于用戶的配置并提供了相關(guān)的掛鉤(hook)和飽和策略來處理滿隊(duì)列

Java線程池會將提交的任務(wù)先置于工作隊(duì)列中,在從工作隊(duì)列中獲取(SynchronousQueue直接由生產(chǎn)者提交給工作線程)。那么工作隊(duì)列就有兩種實(shí)現(xiàn)策略:無界隊(duì)列和有界隊(duì)列。無界隊(duì)列不存在飽和的問題,但是其問題是當(dāng)請求持續(xù)高負(fù)載的話,任務(wù)會無腦的加入工作隊(duì)列,那么很可能導(dǎo)致內(nèi)存等資源溢出或者耗盡。而有界隊(duì)列不會帶來高負(fù)載導(dǎo)致的內(nèi)存耗盡的問題,但是有引發(fā)工作隊(duì)列已滿情況下,新提交的任務(wù)如何管理的難題,這就是線程池工作隊(duì)列飽和策略要解決的問題。

飽和策略分為:Abort 策略, CallerRuns 策略,Discard策略,DiscardOlds策略。

為了更好的理解,我編寫一個(gè)小的例子。

package concurrency.pool;
import java.util.concurrent.LinkedBlockingDeque;
import java.util.concurrent.RejectedExecutionHandler;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
public class SaturationPolicy {
	/**
   * 線程池工作隊(duì)列已滿時(shí),在不同飽和策略下表現(xiàn)
   * @param handler 線程池工作隊(duì)列飽和策略
   */
	public static void policy(RejectedExecutionHandler handler){
		//基本線程2個(gè),最大線程數(shù)為3,工作隊(duì)列容量為5
		ThreadPoolExecutor exec = new ThreadPoolExecutor(2,3,0l, TimeUnit.MILLISECONDS,new LinkedBlockingDeque<>(5));
		if (handler != null){
			exec.setRejectedExecutionHandler(handler);
			//設(shè)置飽和策略
		}
		for (int i = 0; i < 10; i++) {
			exec.submit(new Task());
			//提交任務(wù)
		}
		exec.shutdown();
	}
	public static void main(String[] args) {
		//    policy(new ThreadPoolExecutor.AbortPolicy());
		//    policy((new ThreadPoolExecutor.CallerRunsPolicy()));
		//    policy(new ThreadPoolExecutor.DiscardPolicy());
		//    policy(new ThreadPoolExecutor.DiscardOldestPolicy());
	}
	//自定義任務(wù)
	static class Task implements Runnable {
		private static int count = 0;
		private int id = 0;
		//任務(wù)標(biāo)識
		public Task() {
			id = ++count;
		}
		@Override
		    public void run() {
			try {
				TimeUnit.SECONDS.sleep(3);
				//休眠3秒
			}
			catch (InterruptedException e) {
				System.err.println("線程被中斷" + e.getMessage());
			}
			System.out.println(" 任務(wù):" + id + "\t 工作線程: "+ Thread.currentThread().getName() + " 執(zhí)行完畢");
		}
	}
}

當(dāng)工作隊(duì)列滿了,不同策略的處理方式為:

1.Abort策略:默認(rèn)策略,新任務(wù)提交時(shí)直接拋出未檢查的異常RejectedExecutionException,該異??捎烧{(diào)用者捕獲。
在主函數(shù)中添加如下代碼:

policy(new ThreadPoolExecutor.AbortPolicy()); 

運(yùn)行結(jié)果為:

程序拋出了RejectedExecutionException,并且一共運(yùn)行了8個(gè)任務(wù)(線程池開始能運(yùn)行3個(gè)任務(wù),工作隊(duì)列中存儲5個(gè)隊(duì)列)。當(dāng)工作隊(duì)列滿了的時(shí)候,直接拋出了異常,而且JVM一直不退出(我現(xiàn)在也不知道什么原因)。我們可以看到執(zhí)行任務(wù)的線程全是線程池中的線程。

2.CallerRuns策略:為調(diào)節(jié)機(jī)制,既不拋棄任務(wù)也不拋出異常,而是將某些任務(wù)回退到調(diào)用者。不會在線程池的線程中執(zhí)行新的任務(wù),而是在調(diào)用exector的線程中運(yùn)行新的任務(wù)。

在主函數(shù)運(yùn)行:

policy((new ThreadPoolExecutor.CallerRunsPolicy())); 

運(yùn)行結(jié)果

所有的任務(wù)都被運(yùn)行,且有2(10 - 3 -5)個(gè)任務(wù)是在main線程中執(zhí)行成功的,8個(gè)任務(wù)在線程池中的線程執(zhí)行的。
3.Discard策略:新提交的任務(wù)被拋棄。
在main函數(shù)中運(yùn)行

policy(new ThreadPoolExecutor.DiscardPolicy()); 

通過上面的結(jié)果可以顯示:沒有異常拋出,后面提交的2個(gè)新任務(wù)被拋棄,只處理了前8(3+5)個(gè)任務(wù),JVM退出。

4.DiscardOldest策略:隊(duì)列的是“隊(duì)頭”的任務(wù),然后嘗試提交新的任務(wù)。(不適合工作隊(duì)列為優(yōu)先隊(duì)列場景)

在main函數(shù)中運(yùn)行如下方法

policy(new ThreadPoolExecutor.DiscardOldestPolicy()); 

運(yùn)行結(jié)果:一共運(yùn)行8個(gè)任務(wù),程序結(jié)束,后面添加的任務(wù)9,任務(wù)10被執(zhí)行了,而前面的任務(wù)3,任務(wù)4被丟棄。

總結(jié)

以上就是本文關(guān)于java線程池工作隊(duì)列飽和策略代碼示例的全部內(nèi)容,希望對大家有所幫助。如有不足之處,歡迎留言指出。感謝朋友們對本站的支持。

相關(guān)文章

  • SpringBoot中配置nacos的方法實(shí)現(xiàn)

    SpringBoot中配置nacos的方法實(shí)現(xiàn)

    本文主要介紹了SpringBoot中配置nacos的方法實(shí)現(xiàn),文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2024-08-08
  • JavaWeb中Servlet的生命周期及線程安全問題詳解

    JavaWeb中Servlet的生命周期及線程安全問題詳解

    這篇文章主要介紹了JavaWeb中Servlet的生命周期及線程安全問題詳解,Servlet?生命周期可被定義為從創(chuàng)建直到毀滅的整個(gè)過程,Servlet體系結(jié)構(gòu)是建立在Java多線程機(jī)制之上的,它的生命周期是由Web容器負(fù)責(zé)的,需要的朋友可以參考下
    2024-01-01
  • Spring?Boot實(shí)現(xiàn)MyBatis動態(tài)創(chuàng)建表的操作語句

    Spring?Boot實(shí)現(xiàn)MyBatis動態(tài)創(chuàng)建表的操作語句

    這篇文章主要介紹了Spring?Boot實(shí)現(xiàn)MyBatis動態(tài)創(chuàng)建表,MyBatis提供了動態(tài)SQL,我們可以通過動態(tài)SQL,傳入表名等信息然組裝成建表和操作語句,本文通過案例講解展示我們的設(shè)計(jì)思路,需要的朋友可以參考下
    2024-01-01
  • Reactive Programming入門概念詳解

    Reactive Programming入門概念詳解

    這篇文章主要為大家介紹了Reactive Programming入門概念詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-09-09
  • java中1+1d/5和1+1/5的區(qū)別說明

    java中1+1d/5和1+1/5的區(qū)別說明

    這篇文章主要介紹了java中1+1d/5和1+1/5的區(qū)別說明,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • Shiro:自定義Realm實(shí)現(xiàn)權(quán)限管理方式

    Shiro:自定義Realm實(shí)現(xiàn)權(quán)限管理方式

    這篇文章主要介紹了Shiro:自定義Realm實(shí)現(xiàn)權(quán)限管理方式,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-10-10
  • 在IntelliJ IDEA中.idea文件是什么可以刪除嗎

    在IntelliJ IDEA中.idea文件是什么可以刪除嗎

    相信有很多小伙伴,在用idea寫java代碼的時(shí)候,創(chuàng)建工程總是會出現(xiàn).idea文件,該文件也從來沒去打開使用過,那么它在我們項(xiàng)目里面,扮演什么角色,到底能不能刪除它呢?這篇文章主要介紹了在IntelliJ IDEA中.idea文件是什么可以刪除嗎,需要的朋友可以參考下
    2024-01-01
  • Java導(dǎo)出excel時(shí)合并同一列中相同內(nèi)容的行思路詳解

    Java導(dǎo)出excel時(shí)合并同一列中相同內(nèi)容的行思路詳解

    這篇文章主要介紹了Java導(dǎo)出excel時(shí)合并同一列中相同內(nèi)容的行,需要的朋友可以參考下
    2018-06-06
  • spring-data-redis 2.0 的使用示例代碼

    spring-data-redis 2.0 的使用示例代碼

    這篇文章主要介紹了spring-data-redis 2.0 的使用示例代碼,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-01-01
  • SpringBoot淺析安全管理之高級配置

    SpringBoot淺析安全管理之高級配置

    安全管理是軟件系統(tǒng)必不可少的的功能。根據(jù)經(jīng)典的“墨菲定律”——凡是可能,總會發(fā)生。如果系統(tǒng)存在安全隱患,最終必然會出現(xiàn)問題,這篇文章主要介紹了SpringBoot安全管理之高級配置
    2022-08-08

最新評論