Java 守護(hù)線程_動力節(jié)點Java學(xué)院整理
估計學(xué)過Unix開發(fā)但是沒有細(xì)致學(xué)習(xí)Java的同學(xué)們會疑惑了,操作系統(tǒng)里面是沒有所謂的守護(hù)線程的概念,只有守護(hù)進(jìn)程一說,但是Java語言機(jī)制是構(gòu)建在JVM的基礎(chǔ)之上的,意思是Java平臺把操作系統(tǒng)的底層給屏蔽起來,所以它可以在它自己的虛擬的平臺里面構(gòu)造出對自己有利的機(jī)制,而語言或者說平臺的設(shè)計者多多少少是收到Unix思想的影響,而守護(hù)線程機(jī)制又是對JVM這樣的平臺湊合,于是守護(hù)線程應(yīng)運而生。
Daemon的作用是為其他線程的運行提供服務(wù),比如說GC線程。其實User Thread線程和Daemon Thread守護(hù)線程本質(zhì)上來說去沒啥區(qū)別的,唯一的區(qū)別之處就在虛擬機(jī)的離開:如果User Thread全部撤離,那么Daemon Thread也就沒啥線程好服務(wù)的了,所以虛擬機(jī)也就退出了。
守護(hù)線程并非虛擬機(jī)內(nèi)部可以提供,用戶也可以自行的設(shè)定守護(hù)線程,方法:public final void setDaemon(boolean on) ;但是有幾點需要注意:
1)、thread.setDaemon(true)必須在thread.start()之前設(shè)置,否則會跑出一個IllegalThreadStateException異常。你不能把正在運行的常規(guī)線程設(shè)置為守護(hù)線程。 (備注:這點與守護(hù)進(jìn)程有著明顯的區(qū)別,守護(hù)進(jìn)程是創(chuàng)建后,讓進(jìn)程擺脫原會話的控制+讓進(jìn)程擺脫原進(jìn)程組的控制+讓進(jìn)程擺脫原控制終端的控制;所以說寄托于虛擬機(jī)的語言機(jī)制跟系統(tǒng)級語言有著本質(zhì)上面的區(qū)別)
2)、 在Daemon線程中產(chǎn)生的新線程也是Daemon的。 (這一點又是有著本質(zhì)的區(qū)別了:守護(hù)進(jìn)程fork()出來的子進(jìn)程不再是守護(hù)進(jìn)程,盡管它把父進(jìn)程的進(jìn)程相關(guān)信息復(fù)制過去了,但是子進(jìn)程的進(jìn)程的父進(jìn)程不是init進(jìn)程,所謂的守護(hù)進(jìn)程本質(zhì)上說就是“父進(jìn)程掛掉,init收養(yǎng),然后文件0,1,2都是/dev/null,當(dāng)前目錄到/”)
3)、不是所有的應(yīng)用都可以分配給Daemon線程來進(jìn)行服務(wù),比如讀寫操作或者計算邏輯。因為在Daemon Thread還沒來的及進(jìn)行操作時,虛擬機(jī)可能已經(jīng)退出了。
例子:
//完成文件輸出的守護(hù)線程任務(wù)
import java.io.*;
class TestRunnable implements Runnable{
public void run(){
try{
Thread.sleep(1000);//守護(hù)線程阻塞1秒后運行
File f=new File("daemon.txt");
FileOutputStream os=new FileOutputStream(f,true);
os.write("daemon".getBytes());
}
catch(IOException e1){
e1.printStackTrace();
}
catch(InterruptedException e2){
e2.printStackTrace();
}
}
}
public class TestDemo2{
public static void main(String[] args) throws InterruptedException
{
Runnable tr=new TestRunnable();
Thread thread=new Thread(tr);
thread.setDaemon(true); //設(shè)置守護(hù)線程
thread.start(); //開始執(zhí)行分進(jìn)程
}
}
運行結(jié)果:文件daemon.txt中沒有"daemon"字符串。
但是如果把thread.setDaemon(true); //設(shè)置守護(hù)線程注釋掉,文件daemon.txt是可以被寫入daemon字符串的

JRE判斷程序是否執(zhí)行結(jié)束的標(biāo)準(zhǔn)是所有的前臺執(zhí)線程行完畢了,而不管后臺線程的狀態(tài),因此,在使用后臺線程候一定要注意這個問題。
但是daemon Thread實際應(yīng)用在那里呢?舉個例子,web服務(wù)器中的Servlet,容器啟動時后臺初始化一個服務(wù)線程,即調(diào)度線程,負(fù)責(zé)處理http請求,然后每個請求過來調(diào)度線程從線程池中取出一個工作者線程來處理該請求,從而實現(xiàn)并發(fā)控制的目的。
網(wǎng)上摘的一個圖,方便大家理解:

以上所述是小編給大家介紹的Java 守護(hù)線程,希望對大家有所幫助,如果大家有任何疑問請給我留言,小編會及時回復(fù)大家的。在此也非常感謝大家對腳本之家網(wǎng)站的支持!
- Java并發(fā)編程示例(七):守護(hù)線程的創(chuàng)建和運行
- Java線程之守護(hù)線程(Daemon)用法實例
- 淺談java的守護(hù)線程與非守護(hù)線程
- 淺談java中守護(hù)線程與用戶線程
- 簡單了解Java編程中線程的創(chuàng)建與守護(hù)線程
- Java守護(hù)線程實例詳解_動力節(jié)點Java學(xué)院整理
- Java語言多線程終止中的守護(hù)線程實例
- 詳解Java線程-守護(hù)線程與用戶線程
- 【java 多線程】守護(hù)線程與非守護(hù)線程的詳解
- Java后臺線程操作示例【守護(hù)線程】
- Java守護(hù)線程用法實例分析
相關(guān)文章
詳解Java synchronized關(guān)鍵字的用法
在多線程編程中常常使用鎖機(jī)制來確保同一時刻只有一個線程能夠修改共享內(nèi)存,在Java中一般是使用synchronized作為鎖機(jī)制,下面就讓我們來學(xué)習(xí)一下如何使用synchronized實現(xiàn)線程安全吧2023-08-08
基于Transactional事務(wù)的使用以及注意說明
這篇文章主要介紹了Transactional事務(wù)的使用以及注意說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-07-07
MyBatis中使用foreach循環(huán)的坑及解決
這篇文章主要介紹了MyBatis中使用foreach循環(huán)的坑及解決方案,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2022-01-01

