Java多線程(五)、多線程其他知識簡要介紹

一、線程組

[java]view plaincopy

/**

*?A?thread?group?represents?a?set?of?threads.?In?addition,?a?thread

*?group?can?also?include?other?thread?groups.?The?thread?groups?form

*?a?tree?in?which?every?thread?group?except?the?initial?thread?group

*?has?a?parent.

*?

*?A?thread?is?allowed?to?access?information?about?its?own?thread

*?group,?but?not?to?access?information?about?its?thread?group's

*?parent?thread?group?or?any?other?thread?groups.

*

*?@author??unascribed

*?@version?1.66,?03/13/08

*?@since???JDK1.0

*/

一個線程組代表了一系列的線程。并且,一個線程組可以包括其他的線程組。除了初始線程組外,每個線程組都有一個父線程組,類似于樹的結(jié)構(gòu)。

一個線程可以訪問它所在線程組的信息, 不可以訪問它父線程組和其他線程組的信息。

從這段話中可以大概明白線程組的概念,所有的線程和線程組構(gòu)成一個樹的結(jié)構(gòu),如下:

查看Thread的API,可以看到,創(chuàng)建一個線程可以指定它的線程組和不指定線程組。如果指定其所屬的線程組,那么該線程組是創(chuàng)建它的線程所屬線程組的子線程組。如果不指定線程組,則屬于默認(rèn)情況,該線程和創(chuàng)建它的線程在同一個線程組。

以上面的圖舉個簡單的例子:

如果main線程創(chuàng)建了Thread1線程,沒有指定Thread1所在的線程組,那么Thread1就默認(rèn)和main線程屬于同一個線程組,即系統(tǒng)線程組。

如果main線程創(chuàng)建了Thread3線程,沒指定Thread3所在的線程組為線程組1,那么線程組1就屬于系統(tǒng)線程組,和main線程在樹結(jié)構(gòu)中平級。

一旦某個線程加入了指定線程組之后,該線程將一直屬于該線程組,直到該線程死亡,線程運行中途不能改變它所屬的線程組。因為指定線程所在線程組是在創(chuàng)建線程的視乎完成的,所以之后不能再修改它所在的線程組。

下面是ThreadGroup的方法摘要

方法摘要

intactiveCount()

返回此線程組中活動線程的估計數(shù)。

intactiveGroupCount()

返回此線程組中活動線程組的估計數(shù)。

booleanallowThreadSuspension(boolean?b)

已過時。此調(diào)用的定義取決于suspend(),它被廢棄了。更進一步地說,此調(diào)用的行為從不被指定。

voidcheckAccess()

確定當(dāng)前運行的線程是否有權(quán)修改此線程組。

voiddestroy()

銷毀此線程組及其所有子組。

intenumerate(Thread[]?list)

把此線程組及其子組中的所有活動線程復(fù)制到指定數(shù)組中。

intenumerate(Thread[]?list, boolean?recurse)

把此線程組中的所有活動線程復(fù)制到指定數(shù)組中。

intenumerate(ThreadGroup[]?list)

把對此線程組中的所有活動子組的引用復(fù)制到指定數(shù)組中。

intenumerate(ThreadGroup[]?list, boolean?recurse)

把對此線程組中的所有活動子組的引用復(fù)制到指定數(shù)組中。

intgetMaxPriority()

返回此線程組的最高優(yōu)先級。

StringgetName()

返回此線程組的名稱。

ThreadGroupgetParent()

返回此線程組的父線程組。

voidinterrupt()

中斷此線程組中的所有線程。

booleanisDaemon()

測試此線程組是否為一個后臺程序線程組。

booleanisDestroyed()

測試此線程組是否已經(jīng)被銷毀。

voidlist()

將有關(guān)此線程組的信息打印到標(biāo)準(zhǔn)輸出。

booleanparentOf(ThreadGroupg)

測試此線程組是否為線程組參數(shù)或其祖先線程組之一。

voidresume()

已過時。此方法只用于聯(lián)合Thread.suspend和ThreadGroup.suspend時,因為它們所固有的容易導(dǎo)致死鎖的特性,所以兩者都已廢棄。有關(guān)詳細(xì)信息,請參閱Thread.suspend()

voidsetDaemon(boolean?daemon)

更改此線程組的后臺程序狀態(tài)。

voidsetMaxPriority(int?pri)

設(shè)置線程組的最高優(yōu)先級。

voidstop()

已過時。此方法具有固有的不安全性。有關(guān)詳細(xì)信息,請參閱Thread.stop()。

voidsuspend()

已過時。此方法容易導(dǎo)致死鎖。有關(guān)詳細(xì)信息,請參閱Thread.suspend()。

StringtoString()

返回此線程組的字符串表示形式。

voiduncaughtException(Threadt,Throwablee)

當(dāng)此線程組中的線程因為一個未捕獲的異常而停止,并且線程沒有安裝特定Thread.UncaughtExceptionHandler時,由 Java Virtual Machine 調(diào)用此方法。

二、線程組與未處理的異常

從JDK1.5開始,Java加強了線程的異常處理,如果線程執(zhí)行過程中拋出了一個未處理的異常,JVM在結(jié)束該線程之前會自動查找是否有對應(yīng)的Thread.UncaughtExceptionHandler對象,如果找到該處理器對象,將會調(diào)用該對象的uncaughtException(Thread t,Throwable e)方法來處理該異常。

Thread.UncaughtExceptionHandler是Thread類的一個內(nèi)部公共靜態(tài)接口,該接口內(nèi)只有一個方法:

void uncaughtException(Thread t,Throwable t),該方法中的t代表出現(xiàn)異常的線程,而e代表該線程拋出的異常。

Thread類提供了兩個方法來設(shè)置異常處理器:

public static void setDefaultUncaughtExceptionHandler(UncaughtExceptionHandler eh)

線程類的所有線程實例設(shè)置默認(rèn)的異常處理器

public void setUncaughtExceptionHandler(UncaughtExceptionHandler eh)

為指定線程的實例設(shè)置異常處理器

ThreadGroup類實現(xiàn)了Thread.UncaughtExceptionHandler接口,所以每個線程所屬的線程組將會作為默認(rèn)的異常處理器。當(dāng)一個線程拋出未處理的異常時,JVM會首先查找該異常對應(yīng)的異常處理器(setUncaughtExceptionHandler方法設(shè)置的異常處理器),如果找到該異常處理器,將調(diào)用該異常處理器處理該異常,否則,JVM將會調(diào)用該線程所屬的線程組對象的uncaughtException方法來處理該異常,線程組處理異常的流程如下:

1)、如果該線程組有父線程組,則調(diào)用父線程組的uncaughtException方法來處理該異常

2)、否則,如果該線程實例所屬的線程類有默認(rèn)的異常處理器(由setDefaultUncaughtExceptionHandler方法設(shè)置的異常處理器),那么就調(diào)用該異常處理器來處理該異常

3)、否則,將異常調(diào)試棧的信息打印到System.err錯誤輸出流,并結(jié)束該線程。

看下面的例子:

[java]view plaincopy

classMyHandlerimplementsThread.UncaughtExceptionHandler{

@Override

publicvoiduncaughtException(Thread?t,?Throwable?e)?{

System.out.println("出現(xiàn)了異常");

e.printStackTrace();

}

}

publicclassTest{

publicstaticvoidmain(String[]?args)?{

Thread.currentThread().setUncaughtExceptionHandler(newMyHandler());

inta=1/0;

}

}

在主線程中設(shè)置了異常處理器,最后捕獲了異常。

三、Callable和Future

參考:http://lavasoft.blog.51cto.com/62575/222082

四、volatile關(guān)鍵字

參考:http://lavasoft.blog.51cto.com/62575/222076

五、顯示同步鎖

參考:http://lavasoft.blog.51cto.com/62575/222084

轉(zhuǎn)自:http://blog.csdn.net/lonelyroamer/article/details/7993502

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
【社區(qū)內(nèi)容提示】社區(qū)部分內(nèi)容疑似由AI輔助生成,瀏覽時請結(jié)合常識與多方信息審慎甄別。
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點,簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。

相關(guān)閱讀更多精彩內(nèi)容

  • 導(dǎo)讀目錄 線程組(ThreadGroup) 線程池(Thread Pool) Fork/Join框架和Execut...
    ql2012jz閱讀 1,572評論 0 0
  • 一、認(rèn)識多任務(wù)、多進程、單線程、多線程 要認(rèn)識多線程就要從操作系統(tǒng)的原理說起。 以前古老的DOS操作系統(tǒng)(V 6....
    GT921閱讀 1,099評論 0 3
  • Spring Cloud為開發(fā)人員提供了快速構(gòu)建分布式系統(tǒng)中一些常見模式的工具(例如配置管理,服務(wù)發(fā)現(xiàn),斷路器,智...
    卡卡羅2017閱讀 136,662評論 19 139
  • Java-Review-Note——4.多線程 標(biāo)簽: JavaStudy PS:本來是分開三篇的,后來想想還是整...
    coder_pig閱讀 1,773評論 2 17
  • 當(dāng)身邊的人紛紛先孕后戀,先孕后婚,閃孕閃婚,我這種領(lǐng)證一年多還未懷孕,真是奇葩了。尤其是五一辦完婚禮后,懷孕的議程...
    芝芝風(fēng)子閱讀 424評論 0 0

友情鏈接更多精彩內(nèi)容