談?wù)凧ava中的守護線程與普通線程
守護線程與普通線程的唯一區(qū)別是:當JVM中所有的線程都是守護線程的時候,JVM就可以退出了;如果還有一個或以上的非守護線程則不會退出。(以上是針對正常退出,調(diào)用System.exit則必定會退出)
所以setDeamon(true)的唯一意義就是告訴JVM不需要等待它退出,讓JVM喜歡什么退出就退出吧,不用管它。
守護線程在沒有用戶線程可服務(wù)時自動離開,在Java中比較特殊的線程是被稱為守護(Daemon)線程的低級別線程。這個線程具有最低的優(yōu)先級,用于為系統(tǒng)中的其它對象和線程提供服務(wù)。將一個用戶線程設(shè)置為守護線程的方式是在線程對象創(chuàng)建之前調(diào)用線程對象的setDaemon方法。典型的守護線程例子是JVM中的系統(tǒng)資源自動回收線程,我們所熟悉的Java垃圾回收線程就是一個典型的守護線程,當我們的程序中不再有任何運行中的Thread,程序就不會再產(chǎn)生垃圾,垃圾回收器也就無事可做,所以當垃圾回收線程是Java虛擬機上僅剩的線程時,Java虛擬機會自動離開。它始終在低級別的狀態(tài)中運行,用于實時監(jiān)控和管理系統(tǒng)中的可回收資源。守護進程(Daemon)是運行在后臺的一種特殊進程。它獨立于控制終端并且周期性地執(zhí)行某種任務(wù)或等待處理某些發(fā)生的事件。也就是說守護線程不依賴于終端,但是依賴于系統(tǒng),與系統(tǒng)“同生共死”。那Java的守護線程是什么樣子的呢。當JVM中所有的線程都是守護線程的時候,JVM就可以退出了;如果還有一個或以上的非守護線程則JVM不會退出。
Java有兩種Thread:“守護線程Daemon”與“用戶線程User”。
我們之前看到的例子都是用戶,守護線程是一種“在后臺提供通用性支持”的線程,它并不屬于程序本體。
從字面上我們很容易將守護線程理解成是由虛擬機(virtual machine)在內(nèi)部創(chuàng)建的,而用戶線程則是自己所創(chuàng)建的。事實并不是這樣,任何線程都可以是“守護線程Daemon”或“用戶線程User”。他們在幾乎每個方面都是相同的,唯一的區(qū)別是判斷虛擬機何時離開:
- 用戶線程:Java虛擬機在它所有非守護線程已經(jīng)離開后自動離開。
- 守護線程:守護線程則是用來服務(wù)用戶線程的,如果沒有其他用戶線程在運行,那么就沒有可服務(wù)對象,也就沒有理由繼續(xù)下去。
setDaemon(boolean on)方法可以方便的設(shè)置線程的Daemon模式,true為Daemon模式,false為User模式。setDaemon(boolean on)方法必須在線程啟動之前調(diào)用,當線程正在運行時調(diào)用會產(chǎn)生異常。isDaemon方法將測試該線程是否為守護線程。值得一提的是,當你在一個守護線程中產(chǎn)生了其他線程,那么這些新產(chǎn)生的線程不用設(shè)置Daemon屬性,都將是守護線程,用戶線程同樣。
package ying.thread;
import java.io.IOException;
public class Test extends Thread {
public Test() {
}
public void run() {
for (int i = 0 ; i < 100 ; i ++) {
try {
Thread.sleep(100) ;
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(i);
}
}
public static void main (String args[]) {
Test test = new Test() ;
test.setDaemon(true) ;
test.start() ;
System.out.println("isDaemon=" + test.isDaemon());
try {
System.in.read() ;
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
如果沒有用戶線程,那么守護線程也沒有存活下去的意義了:
package ying.thread;
import java.io.IOException;
public class Test extends Thread {
public Test() {
}
public void run() {
for (int i = 0 ; i < 100 ; i ++) {
try {
Thread.sleep(100) ;
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
System.out.println(i);
}
}
public static void main (String args[]) {
Test test = new Test() ;
test.setDaemon(true) ;
test.start() ;
System.out.println("isDaemon=" + test.isDaemon());
}
}
這個程序執(zhí)行之后什么也不執(zhí)行;什么也不打??;
如果我們把 thread.setDaemon(true);刪除,那么就可以打印出數(shù)字了。
這就是守護線程,守護著最后一個用戶線程,如果沒有用戶線程了,他也沒作用了。不退出等什么??
以上就是談?wù)凧ava中的守護線程與普通線程的詳細內(nèi)容,更多關(guān)于Java 守護線程與普通線程的資料請關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
IntelliJ IDEA 2020.2正式發(fā)布,兩點多多總能助你提效
這篇文章主要介紹了IntelliJ IDEA 2020.2正式發(fā)布,諸多亮點總有幾款能助你提效,本文通過圖文實例代碼相結(jié)合給大家介紹的非常詳細,需要的朋友可以參考下2020-07-07
純Java類配置與@Configuration實戰(zhàn)指南
本文介紹@Configuration的核心用法,實戰(zhàn)@Bean定義Bean、@ComponentScan掃描組件、@Import組合配置類,帶大家體驗“無XML”的Spring配置新方式,感興趣的朋友跟隨小編一起看看吧2025-09-09
泛談Java中的不可變數(shù)據(jù)結(jié)構(gòu)
開發(fā)人員通常認為擁有final引用,或者val在Kotlin或Scala中,足以使對象不可變。這篇博客文章深入研究了不可變引用和不可變數(shù)據(jù)結(jié)構(gòu),下面小編來和大家一起學習它2019-05-05
springcloud項目快速開始起始模板的實現(xiàn)
本文主要介紹了springcloud項目快速開始起始模板思路的實現(xiàn),文中通過示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下2021-12-12
解決Mybatis-plus自定義TypeHandler查詢映射結(jié)果一直為null問題
這篇文章主要介紹了解決Mybatis-plus自定義TypeHandler查詢映射結(jié)果一直為null問題,具有很好的參考價值,希望對大家有所幫助,如有錯誤或未考慮完全的地方,望不吝賜教2024-07-07
testNG項目通過idea Terminal命令行執(zhí)行的配置過程
這篇文章主要介紹了testNG項目通過idea Terminal命令行執(zhí)行,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學習或工作具有一定的參考借鑒價值,需要的朋友可以參考下2021-07-07

