1、 java命令和 javaw命令是怎么回事?
我現在的理解:
java命令在執行一個class文件的時候,
(1)首先要創建一個虛擬機實例
(2)虛擬機啟動用戶主線程 main()方法,這是非守護線程
(3)虛擬機(也可能是主線程)啟動守護線程。比如垃圾收集線程。
(4)main()方法結束,并且由main()方法創建的用戶線程也結束。也就是說系統中沒有用戶線程存在了,則守護線程也結束,最后虛擬機實例自動銷毀。
javaw命令在eclipse啟動后,也是代表了一個虛擬機實例。它一直存在應該是因為系統中有用戶線程一直在后臺運行。
當eclipse被關閉是,應該是調用了system的exist()方法,即虛擬機實例強行銷毀。
當用戶自己編寫的class文件在eclipse中執行時,由javaw這個虛擬機實例解釋執行。
2、 下面是網上資料總結如下:
Java有兩種Thread:“守護線程Daemon”與“用戶線程User”。
從字面上我們很容易將守護線程理解成是由虛擬機(virtual machine)在內部創建的,而用戶線程則是自己所創建的。事實并不是這樣,任何線程都可以是“守護線程Daemon”或“用戶線程User”。他們在幾乎每個方面都是相同的,唯一的區別是判斷虛擬機何時離開:
用戶線程:Java虛擬機在它所有非守護線程已經離開后自動離開。
守護線程:守護線程則是用來服務用戶線程的,如果沒有其他用戶線程在運行,那么就沒有可服務對象,也就沒有理由繼續下去。
setDaemon(boolean on)方法可以方便的設置線程的Daemon模式,true為Daemon模式,false為User模式。setDaemon(boolean on)方法必須在線程啟動之前調用,當線程正在運行時調用會產生異常。isDaemon方法將測試該線程是否為守護線程。值得一提的是,當你在一個守護線程中產生了其他線程,那么這些新產生的線程不用設置Daemon屬性,都將是守護線程,用戶線程同樣。
下面是演示程序:
----------------------------------------------------------------
import java.io.IOException;
/**
* 守護線程在沒有用戶線程可服務時自動離開
*/
public class TestMain4 extends Thread {
public TestMain4() {
}
public void run() {
for(int i = 1; i <= 50; i++){
try {
Thread.sleep(100);
} catch (InterruptedException ex) {
ex.printStackTrace();
}
System.out.println(i);
}
}
public static void main(String [] args){
TestMain4 test = new TestMain4();
test.setDaemon(false);
test.start();
System.out.println("isDaemon = " + test.isDaemon());
try {
System.in.read(); // 接受輸入,使程序在此停頓,一旦接收到用戶輸入,main線程結束,守護線程自動結束,如果test不是守護進程必須等到test運行完了以后才退出
} catch (Exception ex) {
ex.printStackTrace();
}
}
}
----------------------------------------------------------------------------------
例:我們所熟悉的Java垃圾回收線程就是一個典型的守護線程,當我們的程序中不再有任何運行中的Thread,程序就不會再產生垃圾,垃圾回收器也就無事可做,所以當垃圾回收線程是Java虛擬機上僅剩的線程時,Java虛擬機會自動離開。
3、下面是一個論壇的帖子
http://topic.csdn.net/t/20060115/00/4517316.html
守護線程與普通線程的唯一區別是:當JVM中所有的線程都是守護線程的時候,JVM就可以退出了;如果還有一個或以上的非守護線程則不會退出。(以上是針對正常退出,調用System.exit則必定會退出)
所以setDeamon(true)的唯一意義就是告訴JVM不需要等待它退出,讓JVM喜歡什么退出就退出吧,不用管它。
posted on 2010-04-25 00:06
junly 閱讀(596)
評論(0) 編輯 收藏 所屬分類:
java