java ThreadGroup的作用及方法詳解
ThreadGroup的作用及方法
ThreadGroup線程組,java對這個類的描述呢就是
“線程組表示一組線程。此外,線程組還可以包括其他線程組。線程組形成一個樹,其中除了初始線程組之外的每個線程組都有一個父線程組。
允許線程訪問關于其線程組的信息,但不允許訪問關于其線程組的父線程組或任何其他線程組的信息?!?/p>
ThreadGroup并不是算是標注容器,因為,最后你會發(fā)現(xiàn)這個家伙是沒有public的 add,remove方法的。那怎么把線程放到線程組里面呢?
答案是 在new Thread(參數(shù)),將ThreadGroup當做參數(shù)傳進去。
Field
private final ThreadGroup parent;// 線程組的線程組,final 表名 線程組 不可以隨便變更 String name; //名字 int maxPriority;//這個線程組 的元素 例如 線程 線程組的最大優(yōu)先級,具體實現(xiàn)是 當線程或者線程組自身設定優(yōu)先級的時候,總是取 自己父線程組的優(yōu)先級和要設定的優(yōu)先級的最小值 boolean destroyed;//判斷是否銷毀了 boolean daemon;//當守護進程線程組的最后一個線程停止或最后一個線程組被銷毀時,將自動銷毀該線程組。 int nUnstartedThreads = 0; int nthreads;//這個線程組 里面的線程數(shù)量 Thread threads[];//線程數(shù)組 ,持有 線程的引用 int ngroups;//這個線程組 里面的線程組數(shù)量 ThreadGroup groups[];//線程組數(shù)組 ,持有 線程組的引用
私有構造方法
創(chuàng)建不在任何線程組中的空線程組。
此方法用于創(chuàng)建系統(tǒng)線程組。
private ThreadGroup()
公共構造方法
//創(chuàng)建一個新線程組。這個新組的父線程組是指定的線程組parent。線程組的 名字 就是name 會對 parent 調(diào)用checkAccess() 確定當前運行的線程是否具有修改此線程組的權限(比如 設置setDaemon)。有可能會拋出SecurityException異常 public ThreadGroup(ThreadGroup parent, String name) //構造一個新線程組。這個新組的父線程組是當前運行線程的線程組。 就是調(diào)用上面的方法 public ThreadGroup(String name) { this(Thread.currentThread().getThreadGroup(), name); }
公共方法
public final String getName()//返回線程組名字 //返回父線程組 parent 調(diào)用checkAccess() 確定當前運行的線程是否具有修改此線程組的權限。 //有可能會拋出SecurityException異常 public final ThreadGroup getParent() public final int getMaxPriority() //返回線程組優(yōu)先級 //測試此線程組是否是守護進程線程組。當守護進程線程組的最后一個線程停止或最后一個線程組被銷毀時,將自動銷毀該線程組。 public final boolean isDaemon() public synchronized boolean isDestroyed()//測試該線程組是否已被銷毀。 public final void setDaemon(boolean daemon)//將線程組設置成守護線程組 ,會檢查 當前線程是否具有權限 修改線程組 //設定當前線程組以及子線程組的 優(yōu)先級,取pri和當前線程組的父線程組的優(yōu)先級的較小值為準。 //這個之所以會限制 Thread的最大優(yōu)先級 //具體實現(xiàn)是 當線程或者線程組自身設定優(yōu)先級的時候,總是取 自己父線程組的優(yōu)先級和要設定的優(yōu)先級的最小值 //會檢查 當前線程是否具有權限 修改線程組 public final void setMaxPriority(int pri) //測試,當前這個線程組是否是 g線程組的父線程 或者參數(shù) public final boolean parentOf(ThreadGroup g) //檢查 當前線程是否具有權限 修改線程組 比如在當前線程中 用線程組自己本身調(diào)用它自己的一些方法 ,都會檢查 public final void checkAccess() //返回此線程組及其子線程組中活動線程數(shù)量的估計值。遞歸地遍歷此線程組中的所有子組。 如果當前線程組已經(jīng)destroyed,返回0 public int activeCount() //將線程組的中線程 活動線程放入list[]里面 會自動擴大這個數(shù)組,如果{@code recurse}為{@code true},則此方法遞歸枚舉此線程組的所有子組,并引用這些子組中的每個活動線程 //注意這個聲明數(shù)組的方式 public int enumerate(Thread list[], boolean recurse) //和上面方法類似 只不過 下面這個 ThreadGroup public int enumerate(ThreadGroup list[]) public int enumerate(ThreadGroup list[], boolean recurse) //返回此線程組及其子組中活動組的數(shù)量的估計值。遞歸地遍歷此線程組中的所有子組。 public int activeGroupCount() //interrupt此線程組中的所有線程。包括 子線程組中的線程 public final void interrupt()
特殊的一個方法
public void uncaughtException(Thread t, Throwable e)
這個方法呢,作用很簡單 使 t 線程 拋出一個 Throwable e的異常。這個e 異常 也是你自己定義的。如果前面設置了,
Thread.setDefaultUncaughtExceptionHandler((t, e) -> { System.out.println("默認的 "+t.getName()); System.out.println("默認的 "+e); });
那么,在上面自定義的Throwable 會被這個捕獲,如果沒有設置,就打印標注錯誤流。對這個方法,存在的意義 比較困惑
Thread.setDefaultUncaughtExceptionHandler((t, e) -> { System.out.println("默認的 "+t.getName()); System.out.println("默認的 "+e); }); ThreadGroup threadGroup = new ThreadGroup("father"); Thread two = new Thread(threadGroup,"two"); threadGroup.uncaughtException(two,new IllegalAccessException("ssss"));
運行結(jié)果
線程組(ThreadGroup類)
線程組表示一個線程的集合。線程組也可以包含其他線程組。線程執(zhí)行完就會被回收。
private static void methodA() { MyThread my = new MyThread() ; //創(chuàng)建線程類對象 Thread t1 = new Thread(my, "線程1") ; Thread t2 = new Thread(my, "線程2") ; //public final ThreadGroup getThreadGroup()返回該線程所屬的線程組 ThreadGroup tg1 = t1.getThreadGroup() ; ThreadGroup tg2 = t2.getThreadGroup() ; //public final String getName():返回線程組的名稱 System.out.println(tg1.getName()); //main System.out.println(tg2.getName());//main //所有的線程它默認的線程組名稱:main(主線程),主線程是包含在線程組里面的 System.out.println(Thread.currentThread().getThreadGroup().getName());//main }
private static void methodB() { //public ThreadGroup(String name)構造一個新線程組 ThreadGroup tg = new ThreadGroup("新的線程組") ; MyThread my = new MyThread() ; //Thread(ThreadGroup group, Runnable target, String name) Thread t1 = new Thread(tg, my, "線程1") ; Thread t2 = new Thread(tg, my, "線程2") ; //直接獲取線程組名稱 System.out.println(t1.getThreadGroup().getName()); System.out.println(t2.getThreadGroup().getName()); }
以上為個人經(jīng)驗,希望能給大家一個參考,也希望大家多多支持腳本之家。
相關文章
Springboot 整合shiro實現(xiàn)權限控制的方法
這篇文章主要介紹了Springboot 整合shiro實現(xiàn)權限控制的相關知識,本文通過實例代碼給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2020-11-11Java synchronized線程交替運行實現(xiàn)過程詳解
這篇文章主要介紹了Java synchronized線程交替運行實現(xiàn)過程詳解,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2020-11-11java Comparator.comparing排序使用示例
本文主要介紹了java Comparator.comparing排序使用示例,文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-10-10Java的優(yōu)先隊列PriorityQueue原理及實例分析
這篇文章主要介紹了Java的優(yōu)先隊列PriorityQueue原理解析,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考下2019-12-12springMVC攔截器HandlerInterceptor用法代碼示例
這篇文章主要介紹了springMVC攔截器HandlerInterceptor用法代碼示例,具有一定借鑒價值,需要的朋友可以參考下2017-12-12