博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Java线程:线程的调度-守护线程
阅读量:7220 次
发布时间:2019-06-29

本文共 1550 字,大约阅读时间需要 5 分钟。

守护线程与普通线程写法上基本么啥区别,调用线程对象的方法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
 
从上面的执行结果可以看出:
前台线程是保证执行完毕的,后台线程还没有执行完毕就退出了。
 
实际上:JRE判断程序是否执行结束的标准是所有的前台执线程行完毕了,而不管后台线程的状态,因此,在使用后台县城时候一定要注意这个问题。
本文转自 leizhimin 51CTO博客,原文链接:http://blog.51cto.com/lavasoft/221845,如需转载请自行联系原作者
你可能感兴趣的文章
S3cmd 中国区客户端配置详解
查看>>
不错的Qt, QtCreator学习网址
查看>>
phpMyAmin相关问题解决汇总
查看>>
求最大子序列和
查看>>
php设计模式 - 适配器模式
查看>>
mysql的分区和分表
查看>>
mysql性能查看和配置整理大全
查看>>
zabbix-历史数据清理sql
查看>>
查看机器的硬件信息:
查看>>
迁移工具准备复习
查看>>
中小型企业网络IP地址规划案例-1
查看>>
查询数据库信息
查看>>
mysql主从复制
查看>>
初探Java Builder模式--组装复杂的实力
查看>>
Netty笔记二(发送对象--服务端客户端附可运行源码)
查看>>
ros 设置hotspot认证网段
查看>>
MySQL 超级入门教程
查看>>
Aerospike 数据关系模型
查看>>
VirtualBox 扩充硬盘大小
查看>>
BC95 NCONFIG 配置UE
查看>>