守護線程

Java中的線程分兩類,用戶線程和守護線程。java

咱們以前看到的例子都是用戶,守護線程是一種「在後臺提供通用性支持」的線程,它並不屬於程序本體。 測試

從字面上咱們很容易將守護線程理解成是由虛擬機(virtual machine)在內部建立的,而用戶線程則是本身所建立的。事實並非這樣,任何線程均可以是「守護線程Daemon」或「用戶線程User」。他們在幾乎每一個方面都是相同的,惟一的區別是判斷虛擬機什麼時候離開: 線程

  • 用戶線程:Java虛擬機在它全部非守護線程已經離開後自動離開。 
  • 守護線程:守護線程則是用來服務用戶線程的,若是沒有其餘用戶線程在運行,那麼就沒有可服務對象,也就沒有理由繼續下去。 

setDaemon(boolean on)方法能夠方便的設置線程的Daemon模式,true爲Daemon模式,false爲User模式。setDaemon(boolean on)方法必須在線程啓動以前調用,當線程正在運行時調用會產生異常。isDaemon方法將測試該線程是否爲守護線程。值得一提的是,當你在一個守護線程中產生了其餘線程,那麼這些新產生的線程不用設置Daemon屬性,都將是守護線程,用戶線程一樣。code

public class MyCommon implements Runnable {

    public void run() {
        for (int i = 0; i < 5; i++) {
            System.out.println("MyCommon線程1第" + i + "次執行!");
            try {
                Thread.sleep(7);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
public class MyDaemon implements Runnable {

    public void run() {
        for (long i = 0; i < 9999999L; i++) {
            System.out.println("MyDaemon線程第" + i + "次執行!");
            try {
                Thread.sleep(7);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
        }
    }
}
public class Test {

    public static void main(String[] args) {
        Thread t1 = new Thread(new MyCommon());
        Thread t2 = new Thread(new MyDaemon());
        t2.setDaemon(true);        //設置爲守護線程 

        t2.start();
        t1.start();
    }
}

運行結果:對象

MyCommon線程1第0次執行!
MyDaemon線程第0次執行!
MyDaemon線程第1次執行!
MyCommon線程1第1次執行!
MyCommon線程1第2次執行!
MyDaemon線程第2次執行!
MyCommon線程1第3次執行!
MyDaemon線程第3次執行!
MyDaemon線程第4次執行!
MyCommon線程1第4次執行!
MyDaemon線程第5次執行!虛擬機

從上面的執行結果能夠看出:io

MyCommon線程是保證執行完畢的,MyDaemon線程尚未執行完畢就退出了。
 
實際上:JRE判斷程序是否執行結束的標準是全部的用戶執線程行完畢了,而無論守護線程的狀態,所以,在使用守護線程的時候必定要注意這個問題。class

相關文章
相關標籤/搜索