zoukankan      html  css  js  c++  java
  • Java中的守护线程 & 非守护线程(简介)

    Java中的守护线程 & 非守护线程
    守护线程 (Daemon Thread)
    非守护线程,又称用户线程(User Thread)
    用个比较通俗的比如,任何一个守护线程都是整个JVM中所有非守护线程的保姆:只要当前JVM实例中尚存在任何一个非守护线程没有结束,守护线程就全部工作;只有当最后一个非守护线程结束时,守护线程随着JVM一同结束工作。
    守护线程最典型的应用就是 GC (垃圾回收器)
    守护线程通常是由虚拟机自行创建使用,不过通过编码同样可以创建守护线程,而且 very easy:
    Thread daemonTread = new Thread();
      
      // 设定 daemonThread 为 守护线程,default false(非守护线程)
     daemonThread.setDaemon(true);
      
     // 验证当前线程是否为守护线程,返回 true 则为守护线程
     daemonThread.isDaemon();

    守护线程与普通线程的唯一区别是:当JVM中所有的线程都是守护线程的时候,JVM就可以退出了;如果还有一个或以上的非守护线程则不会退出。(以上是针对正常退出,调用System.exit则必定会退出) 

    所以setDeamon(true)的唯一意义就是告诉JVM不需要等待它退出,让JVM喜欢什么退出就退出吧,不用管它。

    //下面是一个例子

    守护线程与普通线程写法上基本么啥区别,调用线程对象的方法setDaemon(true),则可以将其设置为守护线程。
     
    守护线程使用的情况较少,但并非无用,举例来说,JVM的垃圾回收、内存管理等线程都是守护线程。还有就是在做数据库应用时候,使用的数据库连接池,连接池本身也包含着很多后台线程,监控连接个数、超时时间、状态等等。
     
    setDaemon方法的详细说明:
    public  final  void setDaemon( boolean on)将该线程标记为守护线程或用户线程。当正在运行的线程都是守护线程时,Java 虚拟机退出。    
      该方法必须在启动线程前调用。    

      该方法首先调用该线程的 checkAccess 方法,且不带任何参数。这可能抛出 SecurityException(在当前线程中)。    


       参数: 
        on - 如果为  true,则将该线程标记为守护线程。    
       抛出:    
        IllegalThreadStateException - 如果该线程处于活动状态。    
        SecurityException - 如果当前线程无法修改该线程。 
       另请参见: 
        isDaemon(), checkAccess()

     
    /** 
    * Java线程:线程的调度-守护线程 

    * @author leizhimin 2009-11-4 9:02:40 
    */
     

    public  class Test { 
             public  static  void main(String[] args) { 
                    Thread t1 =  new MyCommon(); 
                    Thread t2 =  new Thread( new MyDaemon()); 
                    t2.setDaemon( true);         //设置为守护线程 

                    t2.start(); 
                    t1.start(); 
            } 


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


    class MyDaemon  implements Runnable { 
             public  void run() { 
                     for ( long i = 0; i < 9999999L; i++) { 
                            System.out.println( "后台线程第" + i +  "次执行!"); 
                             try { 
                                    Thread.sleep(7); 
                            }  catch (InterruptedException e) { 
                                    e.printStackTrace(); 
                            } 
                    } 
            } 
    }
     
    后台线程第0次执行! 
    线程1第0次执行! 
    线程1第1次执行! 
    后台线程第1次执行! 
    后台线程第2次执行! 
    线程1第2次执行! 
    线程1第3次执行! 
    后台线程第3次执行! 
    线程1第4次执行! 
    后台线程第4次执行! 
    后台线程第5次执行! 
    后台线程第6次执行! 
    后台线程第7次执行! 

    Process finished with exit code 0
     
    从上面的执行结果可以看出:
    前台线程是保证执行完毕的,后台线程还没有执行完毕就退出了。
  • 相关阅读:
    自己开发网站全文检索系统
    中国摇滚二十年(经典100首歌曲)
    有一首歌
    Snoopy.class.php使用手册
    wp-Syntax 插件使用方法
    rabbitmq使用
    小程序相关功能的实现
    知识链接
    celery使用
    阿里云服务器部署项目注意事项
  • 原文地址:https://www.cnblogs.com/Free-Thinker/p/3661705.html
Copyright © 2011-2022 走看看