您的位置:首页 > 编程语言 > Java开发

Java线程:线程的调度-守护线程

2017-08-03 14:11 281 查看
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线程:线程的调度-守护线程

 

守护线程与普通线程写法上基本么啥区别,调用线程对象的方法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判断程序是否执行结束的标准是所有的前台执线程行完毕了,而不管后台线程的状态,因此,在使用后台县城时候一定要注意这个问题。

本文出自 “熔 岩” 博客,http://lavasoft.blog.51cto.com/62575/221845
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签:  java