• JAVA面向对象学习——java多线程———控制线程——后台线程


                                后台线程

    有一种线程,它是在后台运行的,它的任务是为其他的线程提供服务,这种线程被称为“后台线程(Daemon Thread)”,又称为“守护线程” 或“精灵线程”。

    JVM的垃圾回收线程就是典型的后台线程。

    后台线程有个特征:如果所有的前台线程都死亡,后台线程会自动死亡。

    调用Thread对象setDaemon(true)方法可将指定线程设置成后台线程。

    =======================================================================

    有一种线程,它是在后台运行的,它的任务是为其他的线程提供服务,这种线程被称为“后台线程(Daemon Thread)”,又称为“守护线程”或“精灵线程”。

    JVM的垃圾回收线程就是典型的后台线程。

    后台线程有个特征:如果所有的前台线程都死亡,后台线程会自动死亡。

    调用Thread对象的setDaemon(true)方法可将指定线程设置成后台线程。

    Thread类还提供了一个isDaemon()方法,用于判断指定线程是否为后台线程。

    注意:

    前台线程死亡后,JVM会通知后台线程死亡,但从它接收指令到做出响应,需要一定时间。

    而且要将某个线程设置为后台线程,必须在该线程启动之前设置,也就是说,setDaemon(true)必须在start()方法之前调用,否则会引发IllegalThreadStateException异常。

     

    =================================================================

    public class DaemonThread extends Thread
    {
    	// 定义后台线程的线程执行体与普通线程没有任何区别
    	public void run()
    	{
    		for (var i = 0; i < 1000; i++)
    		{
    			System.out.println(getName() + "  " + i);
    		}
    	}
    	public static void main(String[] args)
    	{
    		var t = new DaemonThread();
    		// 将此线程设置成后台线程
    		t.setDaemon(true);
    		// 启动后台线程
    		t.start();
    		for (var i = 0; i < 10; i++)
    		{
    			System.out.println(Thread.currentThread().getName()
    				+ "  " + i);
    		}
    		// -----程序执行到此处,前台线程(main线程)结束------
    		// 后台线程也应该随之结束
    	}
    }
    

      

    public class DaemonThread extends Thread
    {
        public void run()
        {
            for (int i = 0; i < 1000; i++)
            {
                System.out.println(getName() + "  " + i);
            }
        }
    
        public static void main(String[] args)
        {
            DaemonThread t = new DaemonThread();
    
            t.setDaemon(true);
    
            t.start();
    
            for (int i = 0; i < 10; i++)
            {
                System.out.println(Thread.currentThread().getName() + "  " + i);
            }
        }
    }
    

      

    下午 06:46:03: Executing task 'DaemonThread.main()'...

    > Task :compileJava UP-TO-DATE
    > Task :processResources NO-SOURCE
    > Task :classes UP-TO-DATE

    > Task :DaemonThread.main()


    main 0
    Thread-0 0
    Thread-0 1
    Thread-0 2
    Thread-0 3
    main 1
    Thread-0 4
    Thread-0 5
    Thread-0 6
    Thread-0 7
    Thread-0 8
    Thread-0 9
    main 2
    main 3
    main 4
    main 5
    Thread-0 10
    Thread-0 11
    main 6
    Thread-0 12
    main 7
    Thread-0 13
    main 8
    main 9
    Thread-0 14
    Thread-0 15
    Thread-0 16
    Thread-0 17
    Thread-0 18
    Thread-0 19
    Thread-0 20
    Thread-0 21
    Thread-0 22
    Thread-0 23
    Thread-0 24
    Thread-0 25

    BUILD SUCCESSFUL in 2s
    2 actionable tasks: 1 executed, 1 up-to-date
    下午 06:46:09: Task execution finished 'DaemonThread.main()'.

  • 相关阅读:
    docker 部署 jenkins
    docker compose 常用命令
    docker compose 安装
    docker swarm 常用命令
    centos7 修改主机名
    docker 修改gwbridge ip address
    docker 创建私有镜像之 registry
    nginx 动静分离之 tomcat
    nginx lnmp之nginx+php
    nginx 配置状态监控
  • 原文地址:https://www.cnblogs.com/xiaobaibailongma/p/16063904.html
Copyright © 2020-2023  润新知