main方法啟動兩個線程之后主線程結束,其他線程並不終止,網絡依然在發送請求,輸出依然存在。
正合我意。
public static void main(String[] args) {
// TODO Auto-generated method stub
fxframe mainframe=new fxframe();
mainframe.go();
}
public void go()
{
buf1=new byte[5000];
running = true;
new Thread() {
public void run()
{
readthread();
};
}.start();
new Thread() {
public void run()
{
netwatch();
};
}.start();
}
這里的問題是沒有分清java的線程模型,jvm不區分主線程和用戶線程,各個線程是獨立的,不同與win32的線程模型。jvm把線程分為前台線程和后台線程,后台線程官方術語叫守護線程,jvm結束的條件是所有的前台線程結束。正常構建的線程都是前台線程,可以在線程未開始前調用Thread類的setDaemon(true)方法將線程改變為后台守護線程。具體運行模型見下例:
===============================================
/**
* 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判斷程序是否執行結束的標准是所有的前台執線程行完畢了,而不管后台線程的狀態,因此,在使用后台縣城時候一定要注意這個問題。
本例子出自“熔 岩”博客http://lavasoft.blog.51cto.com/62575/221845