欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

java線程池詳解及代碼介紹

 更新時間:2021年08月20日 16:14:29   作者:haijiao12138  
這篇文章主要介紹了java中線程池的示例,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧

一.線程池簡介

線程池的概念

線程池就是首先創(chuàng)建一些線程,它們的集合稱為線程池,使用線程池可以很好的提高性能,線程池在系統(tǒng)啟動時既創(chuàng)建大量空閑的線程,程序將一個任務傳給線程池。線程池就會啟動一條線程來執(zhí)行這個任務,執(zhí)行結束后,該線程并不會死亡,而是再次返回線程池中成為空閑狀態(tài),等待執(zhí)行下一個任務。

線程池的工作機制

在線程池的編程模式下,任務是提交給整個線程池,而不是直接提交給某個線程,線程池在拿到任務后,就在內(nèi)部尋找是否有空閑的線程,如果有,則將任務交給某個空閑的線程

一個線程同時只能執(zhí)行一個任務,但可以同時向一個線程池提交多個任務

使用線程池的原因

多線程運行時間,系統(tǒng)不斷的啟動和關閉新線程,成本非常高,會過度消耗系統(tǒng)資源,以及過渡切換線程的危險,從而導致系統(tǒng)資源的崩潰,這時,線程池也就是最好的選擇了

二、四種常見的線程池詳解

線程池的返回值ExecutorService簡介

ExecutorService是Java提供的用于管理線程池的類。該類的兩個作用:控制線程數(shù)量和重用線程

具體的4種常用的線程池實現(xiàn)

1-newCachedThreadPool:創(chuàng)建一個可緩存線程池,如果線程池長度超過處理需要,可靈活回收空閑線程,若無可回收,則新建線程。

2-newFixedThreadPool:創(chuàng)建一個定長線程池,可控制線程最大并發(fā)數(shù),超出的線程會在隊列中等待。

3-newScheduledThreadPool:創(chuàng)建一個定長線程池,支持定時及周期性任務執(zhí)行。

4-newSingleThreadExecutor:創(chuàng)建一個單線程化的線程池,它只會用唯一的工作線程來執(zhí)行任務,保證所有任務按照指定順序(FIFO, LIFO, 優(yōu)先級)執(zhí)行;

1-Executors.newCacheThreadPool()

創(chuàng)建一個可緩存線程池,如果線程池長度超過處理需要,可靈活回收空閑線程,若無可回收,則新建線程。

代碼如下:

/**
 * @author: haijiao12138
 * @ClassName: ThreadPoolExecutorDemo
 * @description: TODO   Executors.newCachedThreadPool() 創(chuàng)建一個可緩存線程池,如果線程池 長 
    度超過處理處理需要,可靈活回收空閑線程  若無可回收 則創(chuàng)建新線程
 *  常見的4種線程池的使用;
 * @date: 2021/8/17 20:17
 */
public class ThreadPoolExecutorDemo {
    public static void main(String[] args) {
        ExecutorService cachedThreadPool = Executors.newCachedThreadPool();
        for (int i = 0; i < 10; i++) {
            try {
              Thread.sleep(1);
            }catch (InterruptedException e) {
                e.printStackTrace();
            }
            cachedThreadPool.execute(new Runnable() {
                @Override
                public void run() {
                    System.out.println(Thread.currentThread().getName()+"正在被執(zhí)行");
                }
            });
        }
    }
}

運行結果如下:

線程池為無限大,當執(zhí)行第二個任務時第一個任務已經(jīng)完成,會復用執(zhí)行第一個任務的線程,而不用每次新建線程。(用休眠來實現(xiàn)第一個任務完成了);

2-Executors.newFixedThreadPool(int n) //括號中存放線程的數(shù)量

創(chuàng)建一個定長線程池,可控制線程最大并發(fā)數(shù),超出的線程會在隊列中等待。

public class ThreadPoolExecutorDemo {
    public static void main(String[] args) {
        //四種常見的線程池
       /*
        1-newCachedThreadPool(); 創(chuàng)建一個可緩存線程池   如果線程池長度超過處理需要   可靈活回收空閑線程  若無可回收  則新建線程
        2-newFixedThreadPool();  創(chuàng)建一個定長線程池  可控制線程最大并發(fā)數(shù)  超出的線程 會在隊列中等得
        3-newScheduledThreadPool();
        4-newSingleThreadExecutor();
        */
       //第二種線程池
        //2-Executors.newFixedThreadPool(int n)
        //創(chuàng)建一個定長線程池,可控制線程最大并發(fā)數(shù),超出的線程會在隊列中等待。
        ExecutorService fixedThreadPool = Executors.newFixedThreadPool(10);//線程池種擁有三個線程
        //創(chuàng)建一個定長線程池,可控制線程最大并發(fā)數(shù),超出的線程會在隊列中等待
        for (int i = 0; i < 10; i++) {
            fixedThreadPool.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        System.out.println(Thread.currentThread().getName()+"正在執(zhí)行!");
                        Thread.sleep(1);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            });
        }
    }
}

執(zhí)行代碼如下:

3-Executors.newScheduledThreadPool(int n);//初始的時候 線程的個數(shù)

延遲5秒執(zhí)行一次:

 ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
        for (int i = 0; i < 3; i++) {
            scheduledThreadPool.schedule(new Runnable() {
                @Override
                public void run() {
                    try {
                        Thread.sleep(1);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                    System.out.println("延遲5秒執(zhí)行:"+Thread.currentThread().getName());
                }
            },5, TimeUnit.SECONDS);
        }

表示延遲1秒后每3秒執(zhí)行一次:

 public static void main(String[] args) {
        ScheduledExecutorService scheduledThreadPool = Executors.newScheduledThreadPool(5);
        //延遲1秒執(zhí)行
        scheduledThreadPool.scheduleAtFixedRate(new Runnable() {
            @Override
            public void run() {
                System.out.println("延遲1秒后每3秒執(zhí)行一次:"+Thread.currentThread().getName());
            }
        }, 1,3 , TimeUnit.MICROSECONDS);
    }

運行結果如下:

4-Executors.newSingleThreadExecutor()

創(chuàng)建一個單線程化的線程池,它只會用唯一的工作線程來執(zhí)行任務,保證所有任務按照指定順序(FIFO, LIFO, 優(yōu)先級)執(zhí)行。

    public static void main(String[] args) {
        //第四種線程池:
        //Executors.newSingleThreadExecutor()
        //創(chuàng)建一個單線程化的線程池,它只會用唯一的工作線程來執(zhí)行任務,保證所有任務按照指定順序(FIFO, LIFO, 優(yōu)先級)執(zhí)行。
        //創(chuàng)建一個單線程化的線程池
        ExecutorService singleThreadExecutor = Executors.newSingleThreadExecutor();
        for (int i = 0; i < 10; i++) {
            final int index = i;
            singleThreadExecutor.execute(new Runnable() {
                @Override
                public void run() {
                    try {
                        //結果依次輸出,相當于順序執(zhí)行各個任務
                        System.out.println(Thread.currentThread().getName()+"正在被執(zhí)行,打印的值是:"+index);
                        Thread.sleep(1000);
                    } catch (InterruptedException e) {
                        e.printStackTrace();
                    }
                }
            });
        }
    }

結果如下:

三、緩沖隊列BlockingQueue和自定義線程池ThreadPoolExecutor

緩沖隊列BlockingQueue簡介:
BlockingQueue是雙緩沖隊列。BlockingQueue內(nèi)部使用兩條隊列,允許兩個線程同時向隊列一個存儲,一個取出操作。在保證并發(fā)安全的同時,提高了隊列的存取效率。
常用的幾種BlockingQueue:
ArrayBlockingQueue(int i):規(guī)定大小的BlockingQueue,其構造必須指定大小。其所含的對象是FIFO順序排序的。
LinkedBlockingQueue()或者(int i):大小不固定的BlockingQueue,若其構造時指定大小,生成的BlockingQueue有大小限制,不指定大小,其大小有Integer.MAX_VALUE來決定。其所含的對象是FIFO順序排序的。
PriorityBlockingQueue()或者(int i):類似于LinkedBlockingQueue,但是其所含對象的排序不是FIFO,而是依據(jù)對象的自然順序或者構造函數(shù)的Comparator決定。
SynchronizedQueue():特殊的BlockingQueue,對其的操作必須是放和取交替完成。
自定義線程池(ThreadPoolExecutor和BlockingQueue連用)

自定義線程池,可以用ThreadPoolExecutor類創(chuàng)建,它有多個構造方法來創(chuàng)建線程池。
常見的構造函數(shù):ThreadPoolExecutor(int corePoolSize, int maximumPoolSize, long keepAliveTime, TimeUnit unit, BlockingQueue workQueue)

示例代碼:

package com.haijiao12138.demo.leetcode.test0817.緩沖隊列;
/**
 * @author: haijiao12138
 * @ClassName: TempThread
 * @description: TODO
 * @date: 2021/8/18 22:24
 */
public class TempThread extends Thread {
    @Override
    public void run() {
        // 打印正在執(zhí)行的緩存線程信息
        System.out.println(Thread.currentThread().getName() + "正在被執(zhí)行");
        try {
            // sleep一秒保證3個任務在分別在3個線程上執(zhí)行
            Thread.sleep(1000);
        } catch (InterruptedException e) {
            e.printStackTrace();
        }
    }
}
package com.haijiao12138.demo.leetcode.test0817.緩沖隊列;
import java.util.concurrent.ArrayBlockingQueue;
import java.util.concurrent.BlockingQueue;
import java.util.concurrent.ThreadPoolExecutor;
import java.util.concurrent.TimeUnit;
/**
 * @author: haijiao12138
 * @ClassName: TestThreadPoolExecutor
 * @description: TODO
 * @date: 2021/8/18 22:28
 */
public class TestThreadPoolExecutor {
    public static void main(String[] args) {
        // 創(chuàng)建數(shù)組型緩沖等待隊列
        BlockingQueue<Runnable> bq = new ArrayBlockingQueue<Runnable>(10);
        // ThreadPoolExecutor:創(chuàng)建自定義線程池,池ThreadPoolExecutor中保存的線程數(shù)為3,允許最大的線程數(shù)為6
        ThreadPoolExecutor tpe = new ThreadPoolExecutor(3, 6, 50, TimeUnit.MILLISECONDS, bq);
        // 創(chuàng)建3個任務
        Runnable t1 = new TempThread();
        Runnable t2 = new TempThread();
        Runnable t3 = new TempThread();

        // 3個任務在分別在3個線程上執(zhí)行
        tpe.execute(t1);
        tpe.execute(t2);
        tpe.execute(t3);

        // 關閉自定義線程池
        tpe.shutdown();
    }
}

總結

本篇文章就到這里了,希望能給你帶來幫助,也希望您能夠多多關注腳本之家的更多內(nèi)容!

相關文章

  • 淺談Spring Bean的作用域之間有什么區(qū)別

    淺談Spring Bean的作用域之間有什么區(qū)別

    Spring的bean有5種作用域是singleton、prototype、request、session和globalSession,本文主要介紹了淺談Spring Bean的作用域之間有什么區(qū)別,感興趣的可以了解一下
    2024-05-05
  • Java代碼是如何被CPU狂飆起來的

    Java代碼是如何被CPU狂飆起來的

    無論是剛剛入門Java的新手還是已經(jīng)工作了的老司機,恐怕都不容易把Java代碼如何一步步被CPU執(zhí)行起來這個問題完全講清楚。本文就帶你詳細了解Java代碼到底是怎么運行起來的。感興趣的同學可以參考閱讀
    2023-03-03
  • java Clone接口和深拷貝詳解

    java Clone接口和深拷貝詳解

    今天小編就為大家分享一篇關于Java Clonable接口和深拷貝詳解上的深入了解,小編覺得內(nèi)容挺不錯的,現(xiàn)在分享給大家,具有很好的參考價值,需要的朋友一起跟隨小編來看看吧
    2021-08-08
  • 解決maven項目tomcat啟動失敗war exploded:Error during artifact deploym問題

    解決maven項目tomcat啟動失敗war exploded:Error during 

    在SpringMVC項目中,使用war和warexploded兩種部署方式可能會導致不同的路徑問題,從而出現(xiàn)404錯誤,war模式將項目打包上傳,而warexploded模式則保持文件夾結構上傳,開發(fā)時建議使用warexploded模式,方便利用Update classes and resources功能自動更新
    2024-10-10
  • Java中斷線程的方法

    Java中斷線程的方法

    這篇文章主要介紹了Java中斷線程的方法,非常不錯,具有參考借鑒價值,需要的朋友可以參考下
    2017-05-05
  • Java應用CPU使用率過高排查方式

    Java應用CPU使用率過高排查方式

    這篇文章主要介紹了Java應用CPU使用率過高排查方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2023-07-07
  • Mybatis如何獲取最新插入數(shù)據(jù)的id

    Mybatis如何獲取最新插入數(shù)據(jù)的id

    這篇文章主要介紹了Mybatis如何獲取最新插入數(shù)據(jù)的id,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • JVM加載class文件的原理機制實例詳解

    JVM加載class文件的原理機制實例詳解

    Java是一種具有動態(tài)性的解釋型語言,類(class)只有被加載到JVM后才能運行,接下來通過本文給大家介紹JVM加載class文件的原理機制詳解,感興趣的朋友一起看看吧
    2022-04-04
  • 深入了解Java行為型設計模式之策略模式

    深入了解Java行為型設計模式之策略模式

    策略模式屬于Java-設計模式中行為模式之一,該模式定義了一系列算法,并將每個算法封裝起來,使它們可以相互替換。本文將通過示例詳細講解這一模式,需要的可以參考一下
    2022-09-09
  • 詳解如何修改idea配置文件位置從C盤更改到D盤

    詳解如何修改idea配置文件位置從C盤更改到D盤

    這篇文章主要給大家介紹了關于如何將idea的配置文件從默認的C盤調整到D盤,從而節(jié)省C盤使用空間,具有很好的參考價值,希望對大家有所幫助,需要的朋友可以參考下
    2023-10-10

最新評論