标签:exception new t 原因 block log 代码块 system sleep public
当前台线程结束后,jvm将直接杀死后台线程,并且后台线程不会去执行finally代码块中的内容
public class DemoThread implements Runnable { @Override public void run() { // TODO Auto-generated method stub try { Thread.currentThread().sleep(1000); System.out.println("我是非守护线程"); } catch (InterruptedException e) { // TODO Auto-generated catch block e.printStackTrace(); }; } }
public class Main { public static void main(String[] args) { threadStart(); } public static void threadStart(){ DemoThread dt = new DemoThread(); Thread thread = new Thread(dt); thread.setDaemon(true); thread.start(); } }
1、当直接启动时,不会打印出内容
2、当去掉thread.setDaemon(true)时,会打印出“我是非守护线程”
原因分析:当thread设置为守护线程时,主线程是前台线程,执行完之后就直接结束,jvm直接kill啦thread这个守护线程,这个守护线程中的内容就不会继续执行下去;当去掉那一行时,thread就默认时前台线程,jvm会等所有前台线程执行完之后才会结束,thread线程即打印出啦内容
标签:exception new t 原因 block log 代码块 system sleep public
原文地址:http://www.cnblogs.com/flymolgee/p/6056414.html