Java多線程的線程守護兩個例子發布者:本站 時間:2020-05-06 14:05:54
核心說明:理解這句話下面可以不看了。
守護與其他線程同時執行,當正在運行的線程都是守護線程時,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()); 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
從上面的執行結果可以看出:
前臺線程是保證執行完畢的,后臺線程還沒有執行完畢就退出了。
實際上:JRE判斷程序是否執行結束的標準是所有的前臺執線程行完畢了,而不管后臺線程的狀態,因此,在使用后臺縣城時候一定要注意這個問題。
后臺線程(守護線程)
所謂的后臺線程,是指在程序運行的時候在后臺提供一種通用服務的線程,并且這種線程并不屬于程序中不可或缺的部分。因此當所有的非后臺線程結束時,程序也就終止了,同時會殺死所有后臺線程。反過來說,只要有任何非后臺線程(用戶線程)還在運行,程序就不會終止。后臺線程在不執行finally子句的情況下就會終止其run方法。后臺線程創建的子線程也是后臺線程。
下面是一個后臺線程的示例:
代碼如下 | |
<span style="font-size:16px;">package demo.thread; import java.util.concurrent.TimeUnit; public class DaemonDemo implements Runnable { @Override public void run() { try { while (true) { Thread.sleep(1000); System.out.println("#" + Thread.currentThread().getName()); } } catch (InterruptedException e) { e.printStackTrace(); } finally {// 后臺線程不執行finally子句 System.out.println("finally "); } } public static void main(String[] args) { for (int i = 0; i < 10; i++) { Thread daemon = new Thread(new DaemonDemo()); // 必須在start之前設置為后臺線程 daemon.setDaemon(true); daemon.start(); } System.out.println("All daemons started"); try { TimeUnit.MILLISECONDS.sleep(1000); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); } } } </span> |
運行結果:
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子句不執行。
選擇我們,優質服務,不容錯過
1. 優秀的網絡資源,強大的網站優化技術,穩定的網站和速度保證
2. 15年上海網站建設經驗,優秀的技術和設計水平,更放心
3. 全程省心服務,不必擔心自己不懂網絡,更省心。
------------------------------------------------------------
24小時聯系電話:021-58370032