Java中的守護執行緒 & 非守護執行緒(簡介)
阿新 • • 發佈:2019-02-02
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則必定會退出)
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
所以setDeamon(true)的唯一意義就是告訴JVM不需要等待它退出,讓JVM喜歡什麼退出就退出吧,不用管它。
//下面是一個例子
守護執行緒與普通執行緒寫法上基本麼啥區別,呼叫執行緒物件的方法setDaemon(true),則可以將其設定為守護執行緒。 守護執行緒使用的情況較少,但並非無用,舉例來說,JVM的垃圾回收、記憶體管理等執行緒都是守護執行緒。還有就是在做資料庫應用時候,使用的資料庫連線池,連線池本身也包含著很多後臺執行緒,監控連線個數、超時時間、狀態等等。 setDaemon方法的詳細說明: public該方法必須在啟動執行緒前呼叫。
該方法首先呼叫該執行緒的 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