摘要:如圖所示,帶有的所有線程構(gòu)造方法都可以定義線程組的。線程組還能統(tǒng)一設(shè)置組內(nèi)所有線程的最高優(yōu)先級,線程多帶帶設(shè)置的優(yōu)先級不會高于線程組設(shè)置的最大優(yōu)先級。
前面的文章,棧長和大家分享過多線程創(chuàng)建的3種方式《實現(xiàn) Java 多線程的 3 種方式》。
但如果線程很多的情況下,你知道如何對它們進行分組嗎?
和 Dubbo 的服務(wù)分組一樣,Java 可以對相同性質(zhì)的線程進行分組。
來看下線程類 Thread 的所有構(gòu)造方法。
如圖所示,帶有 ThreadGroup 的所有線程構(gòu)造方法都可以定義線程組的。
線程組使用 java.lang.ThreadGroup 類定義,它有兩個構(gòu)造方法,第二個構(gòu)造方法允許線程組有父類線程組,也就是說一個線程組可以多個子線程組。
java.lang.ThreadGroup#ThreadGroup(java.lang.String) java.lang.ThreadGroup#ThreadGroup(java.lang.ThreadGroup, java.lang.String)
線程組中比較有用的幾個方法。
// 獲取當(dāng)前線程組內(nèi)的運行線程數(shù)
java.lang.ThreadGroup#activeCount// 中斷線程組內(nèi)的所有線程
java.lang.ThreadGroup#interrupt// 使用 System.out 打印出所有線程信息
java.lang.ThreadGroup#list()
我們來簡單使用下線程組吧!
/** * 微信公眾號:Java技術(shù)棧 */ public static void main(String[] args) { Runnable runnable = () -> { System.out.println("Java技術(shù)棧線程線程組名稱:" + Thread.currentThread().getThreadGroup()); System.out.println("Java技術(shù)棧線程線程名稱:" + Thread.currentThread().getName()); try { Thread.sleep(3000); } catch (InterruptedException e) { e.printStackTrace(); } }; ThreadGroup userGroup = new ThreadGroup("user"); userGroup.setMaxPriority(Thread.MIN_PRIORITY); Thread userTask1 = new Thread(userGroup, runnable, "user-task1"); Thread userTask2 = new Thread(userGroup, runnable, "user-task2"); userTask1.start(); userTask2.start(); System.out.println("Java技術(shù)棧線程線程組活躍線程數(shù):" + userGroup.activeCount()); userGroup.list(); }
程序輸出以下結(jié)果。
Java技術(shù)棧線程線程組名稱:java.lang.ThreadGroup[name=user,maxpri=1] Java技術(shù)棧線程線程名稱:user-task1 Java技術(shù)棧線程線程組活躍線程數(shù):2 Java技術(shù)棧線程線程組名稱:java.lang.ThreadGroup[name=user,maxpri=1] Java技術(shù)棧線程線程名稱:user-task2 java.lang.ThreadGroup[name=user,maxpri=1] Thread[user-task1,1,user] Thread[user-task2,1,user]
根據(jù)示例代碼和程序輸出結(jié)果應(yīng)該對線程組有了一個大概的了解吧。
線程組還能統(tǒng)一設(shè)置組內(nèi)所有線程的最高優(yōu)先級,線程多帶帶設(shè)置的優(yōu)先級不會高于線程組設(shè)置的最大優(yōu)先級。
另外,線程組中有一個 stop 方法用來終止組內(nèi)所有的線程,但這個方法和 Thread 中的 stop 方法一樣會帶來很多問題,所以它們兩個現(xiàn)在都已經(jīng)被廢棄了,官方也是不建議使用了,建議使用線程中斷功能進行優(yōu)雅終止線程。
更多 Java 多線程技術(shù)文章請在微信公眾號后臺回復(fù)關(guān)鍵字:多線程。
本文原創(chuàng)首發(fā)于微信公眾號:Java技術(shù)棧(id:javastack),關(guān)注公眾號在后臺回復(fù) "java" 可獲取更多,轉(zhuǎn)載請原樣保留本信息。
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/72085.html
摘要:昨天棧長介紹了多線程可以分組,還能這樣玩線程分組的妙用。今天,棧長會詳細介紹中的多線程和兩個方法,老司機請?zhí)^,新手或者對這兩個不是很理解的可以繼續(xù)往下看。 昨天棧長介紹了《Java多線程可以分組,還能這樣玩!》線程分組的妙用。今天,棧長會詳細介紹 Java 中的多線程 start() 和 run() 兩個方法,Java 老司機請?zhí)^,新手或者對這兩個不是很理解的可以繼續(xù)往下看。 首先...
摘要:線程池可以用來解決處理一個特定請求最大線程數(shù)量限制問題。安撫多歲的發(fā)發(fā)發(fā)線程池的作用線程池作用就是限制系統(tǒng)中執(zhí)行線程的數(shù)量。若隊列中沒有等待進程,線程池的這一資源處于等待。此線程池支持定時以及周期性執(zhí)行任務(wù)的需求。 前言 面試中我們經(jīng)常會遇到多線程和線程池的問題,究竟如何回答呢?今天關(guān)于Java中的線程池,我們就來學(xué)習(xí)一下。 什么是線程池 線程池是指在初始化一個多線程應(yīng)用程序過程中創(chuàng)建...
摘要:線程池可以用來解決處理一個特定請求最大線程數(shù)量限制問題。安撫多歲的發(fā)發(fā)發(fā)線程池的作用線程池作用就是限制系統(tǒng)中執(zhí)行線程的數(shù)量。若隊列中沒有等待進程,線程池的這一資源處于等待。此線程池支持定時以及周期性執(zhí)行任務(wù)的需求。 前言 面試中我們經(jīng)常會遇到多線程和線程池的問題,究竟如何回答呢?今天關(guān)于Java中的線程池,我們就來學(xué)習(xí)一下。 什么是線程池 線程池是指在初始化一個多線程應(yīng)用程序過程中創(chuàng)建...
摘要:在文章正式發(fā)布,這個逆天新特性教你寫出更牛逼的代碼中,我有介紹到的八個新特性,其中關(guān)于加強部分,我覺得有點意思,這里單獨再拉出來講。是不是很好在將來肯定有武之地如批量讀取文件內(nèi)容到一個中,就能很好的識別行結(jié)束符了。 在文章《Java 11 正式發(fā)布,這 8 個逆天新特性教你寫出更牛逼的代碼》中,我有介紹到 Java 11 的八個新特性,其中關(guān)于 String 加強部分,我覺得有點意思,...
閱讀 3497·2021-11-18 10:02
閱讀 1627·2021-10-12 10:12
閱讀 3011·2021-10-09 09:53
閱讀 4909·2021-09-09 09:34
閱讀 898·2021-09-06 15:02
閱讀 2790·2021-08-05 10:02
閱讀 3154·2019-08-30 15:44
閱讀 3133·2019-08-28 18:04