Java多執行緒的執行緒守護例子
守護執行緒與普通執行緒寫法上基本麼啥區別,呼叫執行緒物件的方法setDaemon(true),則可以將其設定為守護執行緒。下面是小編為大家帶來的Java多執行緒的執行緒守護例子,歡迎閱讀。
Java多執行緒的執行緒守護例子核心說明:理解這句話下面可以不看了。
守護與其他執行緒同時執行,當正在執行的執行緒都是守護執行緒時,Java 虛擬機器退出。
守護執行緒與普通執行緒寫法上基本麼啥區別,呼叫執行緒物件的方法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());
aemon(true); //設定為守護執行緒
t();
t();
}
}
class MyCommon extends Thread {
public void run() {
for (int i = 0; i < 5; i++) {
tln("執行緒1第" + i + "次執行!");
try {
p(7);
} catch (InterruptedException e) {
tStackTrace();
}
}
}
}
class MyDaemon implements Runnable {
public void run() {
for (long i = 0; i < 9999999L; i++) {
tln("後臺執行緒第" + i + "次執行!");
try {
p(7);
} catch (InterruptedException e) {
tStackTrace();
}
}
}
}
後臺執行緒第0次執行!
執行緒1第0次執行!
執行緒1第1次執行!
後臺執行緒第1次執行!
後臺執行緒第2次執行!
執行緒1第2次執行!
執行緒1第3次執行!
後臺執行緒第3次執行!
執行緒1第4次執行!
後臺執行緒第4次執行!
後臺執行緒第5次執行!
後臺執行緒第6次執行!
後臺執行緒第7次執行!
Process finished with exit code 0
從上面的執行結果可以看出:
前臺執行緒是保證執行完畢的,後臺執行緒還沒有執行完畢就退出了。
實際上:JRE判斷程式是否執行結束的標準是所有的前臺執執行緒行完畢了,而不管後臺執行緒的狀態,因此,在使用後臺縣城時候一定要注意這個問題。
後臺執行緒(守護執行緒)
所謂的後臺執行緒,是指在程式執行的時候在後臺提供一種通用服務的執行緒,並且這種執行緒並不屬於程式中不可或缺的部分。因此當所有的非後臺執行緒結束時,程式也就終止了,同時會殺死所有後臺執行緒。反過來說,只要有任何非後臺執行緒(使用者執行緒)還在執行,程式就不會終止。後臺執行緒在不執行finally子句的情況下就會終止其run方法。後臺執行緒建立的子執行緒也是後臺執行緒。
下面是一個後臺執行緒的示例:
程式碼如下
package ad;
import Unit;
public class DaemonDemo implements Runnable {
@Override
public void run() {
try {
while (true) {
p(1000);
tln("#" + entThread()ame());
}
} catch (InterruptedException e) {
tStackTrace();
} finally {// 後臺執行緒不執行finally子句
tln("finally ");
}
}
public static void main(String[] args) {
for (int i = 0; i < 10; i++) {
Thread daemon = new Thread(new DaemonDemo());
// 必須在start之前設定為後臺執行緒
aemon(true);
t();
}
tln("All daemons started");
try {
p(1000);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
tStackTrace();
}
}
}
執行結果:
All daemons started
#Thread-2
#Thread-3
#Thread-1
#Thread-0
#Thread-9
#Thread-6
#Thread-8
#Thread-5
#Thread-7
#Thread-4
分析:從結果可以看出,十個子執行緒並沒有無線迴圈的列印,而是在主執行緒(main())退出後,JVM強制關閉所有後臺執行緒。而不會有任何希望出現的確認形式,如finally子句不執行。