1. 程式人生 > >Java中的守護執行緒 & 非守護執行緒(簡介)

Java中的守護執行緒 & 非守護執行緒(簡介)

Java中的守護執行緒 & 非守護執行緒 守護執行緒 (Daemon Thread) 非守護執行緒,又稱使用者執行緒(User Thread) 用個比較通俗的比如,任何一個守護執行緒都是整個JVM中所有非守護執行緒的保姆:只要當前JVM例項中尚存在任何一個非守護執行緒沒有結束,守護執行緒就全部工作;只有當最後一個非守護執行緒結束時,守護執行緒隨著JVM一同結束工作。 守護執行緒最典型的應用就是 GC (垃圾回收器) 守護執行緒通常是由虛擬機器自行建立使用,不過通過編碼同樣可以建立守護執行緒,而且 very easy: Thread daemonTread = new Thread();   // 設定 daemonThread 為 守護執行緒,default false(非守護執行緒)  daemonThread.setDaemon(true);  // 驗證當前執行緒是否為守護執行緒,返回 true 則為守護執行緒  daemonThread.isDaemon(); 守護執行緒與普通執行緒的唯一區別是:當JVM中所有的執行緒都是守護執行緒的時候,JVM就可以退出了;如果還有一個或以上的非守護執行緒則不會退出。(以上是針對正常退出,呼叫System.exit則必定會退出) 

所以setDeamon(true)的唯一意義就是告訴JVM不需要等待它退出,讓JVM喜歡什麼退出就退出吧,不用管它。

//下面是一個例子

守護執行緒與普通執行緒寫法上基本麼啥區別,呼叫執行緒物件的方法setDaemon(true),則可以將其設定為守護執行緒。 守護執行緒使用的情況較少,但並非無用,舉例來說,JVM的垃圾回收、記憶體管理等執行緒都是守護執行緒。還有就是在做資料庫應用時候,使用的資料庫連線池,連線池本身也包含著很多後臺執行緒,監控連線個數、超時時間、狀態等等。 setDaemon方法的詳細說明: public
  final  void setDaemon( boolean on)將該執行緒標記為守護執行緒或使用者執行緒。當正在執行的執行緒都是守護執行緒時,Java 虛擬機器退出。     
  該方法必須在啟動執行緒前呼叫。     

  該方法首先呼叫該執行緒的 checkAccess 方法,且不帶任何引數。這可能丟擲 SecurityException(在當前執行緒中)。     


   引數:  
    on - 如果為  true,則將該執行緒標記為守護執行緒。     
   丟擲:     
    IllegalThreadStateException - 如果該執行緒處於活動狀態。     
    SecurityException - 如果當前執行緒無法修改該執行緒。  
   另請參見
:  
    isDaemon(), checkAccess() /** 
* Java執行緒:執行緒的排程-守護執行緒 

* @author leizhimin 2009-11-4 9:02:40 
*/
  
public  class Test {  
         public  static  void main(String[] args) {  
                Thread t1 =  new MyCommon();  
                Thread t2 =  new Thread( new MyDaemon());  
                t2.setDaemon( true
);         //設定為守護執行緒  

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

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

class MyDaemon  implements Runnable {  
         public  void run() {  
                 for ( long i = 0; i < 9999999L; i++) {  
                        System.out.println( "後臺執行緒第" + i +  "次執行!");  
                         try {  
                                Thread.sleep(7);  
                        }  catch (InterruptedException e) {  
                                e.printStackTrace();  
                        }  
                }  
        }  
} 後臺執行緒第0次執行!  
執行緒1第0次執行!  
執行緒1第1次執行!  
後臺執行緒第1次執行!  
後臺執行緒第2次執行!  
執行緒1第2次執行!  
執行緒1第3次執行!  
後臺執行緒第3次執行!  
執行緒1第4次執行!  
後臺執行緒第4次執行!  
後臺執行緒第5次執行!  
後臺執行緒第6次執行!  
後臺執行緒第7次執行!  

Process finished with exit code 0 從上面的執行結果可以看出: 前臺執行緒是保證執行完畢的,後臺執行緒還沒有執行完畢就退出了。 來自http://my.oschina.net/heguangdong/blog/27852