zoukankan      html  css  js  c++  java
  • java中的守护线程

    线程分类

    守护线程(即daemon thread),是个服务线程,准确地来说就是服务其他的线程,这是它的作用——而其他的线程只有一种,那就是用户线程。所以java里线程分2种:

    • 用户线程:比如垃圾回收线程,就是最典型的守护线程
    • 守护线程:就是应用程序里的自定义线程

    用户线程举例

    public class UserTest {
        public static void main(String[] args) {
            Thread daemonThread = new Thread(new Runnable() {
                @Override
                public void run() {
                    while (true) {
                        System.out.println("hi daemon....");
                    }
    
                }
            });
            daemonThread.start();
            try {
                Thread.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("main thread is over!");
    
        }
    }

    守护线程举例

    public class DaemonTest {
        public static void main(String[] args) {
            Thread daemonThread = new Thread(new Runnable() {
                @Override
                public void run() {
                    while(true) {
                        System.out.println("hi Daemon....");
                    }
    
                }
            });
            daemonThread.setDaemon(true);
            daemonThread.start();
            try {
                Thread.sleep(1);
            } catch (InterruptedException e) {
                e.printStackTrace();
            }
            System.out.println("main thread is over!");
    
        }
    }

    结果对比

    用户线程中会一直执行下去,守护线程执行一会就结束了。

    定义

    1、守护线程,专门用于服务其他的线程,如果其他的线程(即用户自定义线程)都执行完毕,连main线程也执行完毕,那么jvm就会退出(即停止运行)——此时,连jvm都停止运行了,守护线程当然也就停止执行了。

    2、再换一种说法,如果有用户自定义线程存在的话,jvm就不会退出——此时,守护线程也不能退出,也就是它还要运行,干嘛呢,就是为了执行垃圾回收的任务啊。

    守护进程和用户进程同时执行任务的例子

    #

    public 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();
                }
            }
        }
    }

    #

    public class MyDaemon extends Thread {
        public void run() {
            for (int i = 0; i < 5000; ++i) {
                System.out.println("后台线程1第 " + i + " 次执行");
                try {
                    Thread.sleep(7);
                }catch (InterruptedException e) {
                    e.printStackTrace();
                }
            }
        }
    
        public static void main(String[] args) {
            Thread thread1 = new MyCommon();
            Thread thread2 = new MyDaemon();
            thread2.setDaemon(true);
            thread1.start();
            thread2.start();
        }
    }

    执行结果

    后台线程1第 0 次执行
    线程1第 0 次执行
    后台线程1第 1 次执行
    线程1第 1 次执行
    后台线程1第 2 次执行
    线程1第 2 次执行
    后台线程1第 3 次执行
    线程1第 3 次执行
    后台线程1第 4 次执行
    线程1第 4 次执行
    后台线程1第 5 次执行
    

      

  • 相关阅读:
    P4718 [模板]Pollard-Rho算法
    python爬虫模板
    Codeforces1248F. Catowice City
    P3980 [NOI2008]志愿者招募 (费用流)
    P2805 [NOI2009]植物大战僵尸 (拓扑排序 + 最小割)
    P3157 [CQOI2011]动态逆序对
    P2634 [国家集训队]聪聪可可 (点分治)
    HDU6703 array (线段树)
    Codeforces750E. New Year and Old Subsequence (线段树维护DP)
    Codeforces301D. Yaroslav and Divisors
  • 原文地址:https://www.cnblogs.com/kaituorensheng/p/10087125.html
Copyright © 2011-2022 走看看