简介
在学习多线程的时候经常看到守护线程,但是之前只是知道他是在主线程运行结束之后自动退出,今天看到了它的其他特性,一下做简单介绍。
示例代码
public class DaemonSample {
public static void main(String[] args) throws InterruptedException {
Thread.sleep(1000);
ThreadOne threadOne = new ThreadOne();
threadOne.setDaemon(true);
threadOne.start();
}
}
class ThreadOne extends Thread {
@Override
public void run() {
for (int i = 0; i < 5; i++) {
System.out.println(i);
}
}
}
执行结果
一般情况下没有输出结果,但这不是肯定的,虽然守护线程当中的代码逻辑有for循环,但是在启动它的主线程当中,当start的时候,主线程也刚好结束,因此守护线程还没来得及执行内部代码主线程就结束了,那么守护线程也就跟着结束。
再看这一段代码
public class Threadtest {
public static void main(String[] args) throws InterruptedException {
Thread.sleep(1000);
ThreadOne threadOne = new ThreadOne();
threadOne.setDaemon(true);
threadOne.start();
for (int i = 0; i < 5; i++) {
System.out.print(threadOne.isAlive() + "---");
Thread.currentThread().sleep(1000);
}
}
}
class ThreadOne extends Thread {
@Override
public void run() {
for (int i = 0; i < 15; i++) {
System.out.print(i + "---");
try {
sleep(100);
} catch (InterruptedException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
}
执行结果
根据执行结果可知,守护线程中的代码逻辑执行完的时候isAlive的结果是false,也就是说,守护线程先于主线程结束。由此可知,守护线程并不是一定在主线程结束的时候才会结束,假如守护线程代码逻辑不是无限循环,而且守护线程的逻辑在主线程之前运行结束,那么守护线程会先于主线程结束。
总结
守护线程的结束与否有两个因素。第一:开启它的线程的主线程是否结束;第二:守护线程本身是否结束。这里又分为了两种情况,
第一种:主线程结束,守护线程内部代码逻辑还没有执行完;此时根据守护线程的特性,主线程结束时,不管守护线程代码逻辑是否执行完,守护线程立即结束。
第二种:主线程还没有结束,守护线程内部代码逻辑已经执行完;此时虽然主线程仍然存活,但是守护线程代码逻辑已经结束,因此守护线程先于主线程结束。