java語言

當前位置 /首頁/計算機/java語言/列表

Java多執行緒的執行緒守護例子

守護執行緒與普通執行緒寫法上基本麼啥區別,呼叫執行緒物件的方法setDaemon(true),則可以將其設定為守護執行緒。下面是小編為大家帶來的Java多執行緒的執行緒守護例子,歡迎閱讀

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子句不執行。