Java 語言守護線程 Daemon Thread使用示例詳解
守護線程
在Java語言中有兩類線程:用戶線程和守護線程。我們通俗的講,任意一個守護線程都是整個JVM中所有線程的"大管家";只要當前Java虛擬機中還有任意一個非守護線程沒有結(jié)束,它們的守護線程就不能結(jié)束,要持續(xù)工作;只有當最后一個非守護線程結(jié)束時,守護線程才隨著Java虛擬機一起結(jié)束工作。
- 其作用就是為其他線程的運行提供服務,就像是一個護道者,保證其他線程的順利運行
用戶線程設(shè)為守護線程
我們將用戶線程設(shè)為守護線程的辦法就是Thread類的setDaemon(true)方法。 假設(shè)我們創(chuàng)建一個線程t,然后我們將它設(shè)為守護線程,這時我們就應該注意:
- 守護線程應該永遠不會去訪問系統(tǒng)資源(比如數(shù)據(jù)庫、文件等),因為它會在任何時候甚至正在進行某種操作時發(fā)生中斷。
- 守護線程在運行期間定義并由守護線程創(chuàng)建的線程,都自然而然地是守護線程
- t.setDaemon(true)必須在t.start()之前調(diào)用,否則會發(fā)生IllegalThreadStateException異常。原因是不能把正在運行的常規(guī)線程設(shè)為守護線程
- 代碼示例
public class SubThread extends Thread{
int u1,v1;
int result=0;
//構(gòu)造方法
public SubThread(String name){
super(name);
//隨機產(chǎn)生0~100以內(nèi)的整數(shù)
u1=(int)(Math.random()*100);
v1=(int)(Math.random()*100);
}
@Override
public void run() {
//如果沒有最大公約數(shù),就進行計算
if (result==0){
result=this.getMaxCommonDivisor();
System.out.println ("運行····"+this);
while (true){
Thread.yield (); //暫停當前線程,執(zhí)行其他線程
}
}
}
//得到最大公約數(shù)
public int getMaxCommonDivisor() {
int u=u1,v=v1,r=u;
while (r!=0){
u=v;
v=r;
r=u%v;
}
return v;
}
@Override
public String toString() {
String msg;
msg="threadName:"+this.getName ()+", ahead(優(yōu)先級):"+getPriority ();
String msg1=this.isDaemon ()?",守護線程:" :"用戶線程";
msg=msg+msg1+".["+u1+","+v1+"的最大公約數(shù)是"+result+"]";
return msg;
}
}
注意: public int getMaxCommonDivisor():該方法是為了得到u1、v1的最大公約數(shù)
以上就是Java 語言守護線程 Daemon Thread使用示例詳解的詳細內(nèi)容,更多關(guān)于Java 守護線程Daemon Thread的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
詳解MyBatis的動態(tài)SQL實現(xiàn)原理
MyBatis提供了強大的動態(tài)SQL語句生成功能,以應對復雜的業(yè)務場景,本篇文章將結(jié)合MyBatis解析SQL語句的過程對MyBatis中對<if>,<where>,<foreach>等動態(tài)SQL標簽的支持進行分析,需要的朋友可以參考下2023-07-07
SpringBoot使用JDBC獲取相關(guān)的數(shù)據(jù)方法
這篇文章主要介紹了SpringBoot使用JDBC獲取相關(guān)的數(shù)據(jù)方法,JDBC與數(shù)據(jù)庫建立連接、發(fā)送 操作數(shù)據(jù)庫的語句并處理結(jié)果,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧2019-03-03
Mybatis-plus使用selectList查詢數(shù)據(jù)為null的問題及解決辦法
這篇文章主要介紹了Mybatis-plus使用selectList查詢數(shù)據(jù)為null的問題及解決方法,本文給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2022-07-07

