守护线程

守护线程与普通线程写法上基本没啥区别,调用线程对象的方法setDaemon(true),则可以将其设置为守护线程。
守护线程使用的情况较少,但并非无用,举例来说,JVM的垃圾回收、内存管理等线程都是守护线程。还有就是在做数据库应用时候,使用的数据库连接池,连接池本身也包含着很多后台线程,监控连接个数、超时时间、状态等等
setDaemon方法详细说明

public final void setDaemon(boolean on):将该线程标记为守护线程或用户线程。当正在运行的线程都是守护线程时,Java 虚拟机退出该方法必须在启动线程前调用。 该方法首先调用该线程的 checkAccess 方法,且不带任何参数。这可能抛出 SecurityException(在当前线程中)。 参数:

  1. on - 如果为 true,则将该线程标记为守护线程。

抛出:

  1. IllegalThreadStateException - 如果该线程处于活动状态。
  2. SecurityException - 如果当前线程无法修改该线程。
  1. /**
  2. * Java线程:线程的调度-守护线程
  3. */
  4. public class Test {
  5. public static void main(String[] args) {
  6. Thread t1 = new MyCommon();
  7. Thread t2 = new Thread(new MyDaemon());
  8. t2.setDaemon(true); //设置为守护线程
  9. t2.start();
  10. t1.start();
  11. }
  12. }
  13. class MyCommon extends Thread {
  14. public void run() {
  15. for (int i = 0; i < 5; i++) {
  16. System.out.println("线程1第" + i + "次执行!");
  17. try {
  18. Thread.sleep(7);
  19. } catch (InterruptedException e) {
  20. e.printStackTrace();
  21. }
  22. }
  23. }
  24. }
  25. class MyDaemon implements Runnable {
  26. public void run() {
  27. for (long i = 0; i < 9999999L; i++) {
  28. System.out.println("后台线程第" + i + "次执行!");
  29. try {
  30. Thread.sleep(7);
  31. } catch (InterruptedException e) {
  32. e.printStackTrace();
  33. }
  34. }
  35. }
  36. }
  37. 复制代码

执行结果:

  1. 后台线程第0次执行!
  2. 线程10次执行!
  3. 线程11次执行!
  4. 后台线程第1次执行!
  5. 后台线程第2次执行!
  6. 线程12次执行!
  7. 线程13次执行!
  8. 后台线程第3次执行!
  9. 线程14次执行!
  10. 后台线程第4次执行!
  11. 后台线程第5次执行!
  12. 后台线程第6次执行!
  13. 后台线程第7次执行!
  14. 复制代码

从上面的执行结果可以看出:前台线程是保证执行完毕的,后台线程还没有执行完毕就退出了

实际上:JRE判断程序是否执行结束的标准是所有的前台执线程行完毕了,而不管后台线程的状态,因此,在使用后台线程时候一定要注意这个问题