1守护线程定义与作用
在Java中有2类线程,User Thread(用户线程)、Daemon Thread(守护线程),用个通俗的比喻就是:任何一个守护线程都是整个JVM中所有非守护线程的保姆:只要JVM中存在任何一个非守护线程没有结束,守护线程就全部工作;只有当最后一个非守护线程结束时,守护线程随着JVM一起结束工作。
Daemon Thread的作用是为其他线程的运行提供服务,守护线程最典型的应用就是GC(垃圾回收器)。
User Thread和Daemon Thread几乎没有区别,唯一的不同之处在于虚拟机的离开:如果所有User Thread已经全部退出,只剩下Daemon Thread存在了,虚拟机也就退出了。因为没有了被守护者,Daemon Thread也就没有工作可以做了,也就是没有继续运行的必要了
2设置守护线程
使用Thread的setDaemon方法即可将普通线程设置为守护线程
Thread daemonTread = new Thread();
// 设定 daemonThread 为 守护线程,default false(非守护线程)
daemonThread.setDaemon(true);
// 验证当前线程是否为守护线程,返回 true 则为守护线程
daemonThread.isDaemon();
注意:
(1)setDaemon(true)必须在thread.start()方法之前设置,否则会抛出IllegalThreadStateException。不能把正在运行的线程设置为守护线程
(2)在Daemon线程中产生的新线程都是Daemon的
(3)不要认为所有的应用都可以分配给Daemon线程来进行服务,比如读写操作或者逻辑计算
因为不可能知道在所有的User完成之前,Daemon是否已经完成了预期的服务任务,一旦User Thread退出了,可能大量数据还没有来得及处理,这对程序来说是毁灭性的,因为:一旦所有的User Thread离开了,虚拟机也就退出了
public class TestThread
{
public static void main(String[] args) throws InterruptedException
{
Thread thread = new Thread(new Output());
thread.setDaemon(true);
thread.start();
Thread.sleep(2000);
}
}
class Output implements Runnable
{
@Override
public void run()
{
for(int i=0; i<10; i++)
{
System.out.println(i);
try
{
Thread.sleep(500);
}
catch (InterruptedException e)
{
e.printStackTrace();
}
}
}
}
输出为:
0
1
2
3
4
可以看出,守护线程中的操作并没有执行完毕