一、守护线程概述
在Java中有两类线程:用户线程、守护线程
后台线程也叫守护线程,通常在后台默默执行。其实用户线程和守护线程几乎没有什么区别,唯一不同就是虚拟机的离开方式不同,如果用户线程已经全部退出去了,只剩下守护线程了,虚拟机也就退出了。因为没有被守护者,守护线程也就没有工作可言了,也就没有继续运行程序的必要了。
二、API
setDaemon(boolean on) | 设置线程为后台线程(守护线程)。必须在调用stat()方法之前才有效 |
---|---|
isDaemon( ) | 测试线程是否为后台线程 |
三、实例演示(代码)
代码如下(守护线程):
public class MyRunnableImpl implements Runnable{// 连接Runnable接口
@Override
public void run() { //重写run方法
String name = Thread.currentThread().getName();// 获取子线程的名字
int i = 0;
while(true) { // 测试用的while死循环
System.out.println(name+",i="+i);
i++;
}
}
}
代码如下(测试):
public class Test01 {
public static void main(String[] args) {
String name = Thread.currentThread().getName();// 获取当前主线程的名字
MyRunnableImpl myRunnableImpl = new MyRunnableImpl();// 创建子线程
Thread thread = new Thread(myRunnableImpl);
thread.setDaemon(true); // 将子线程设置成守护线程
thread.start(); // 启动守护线程
for(int i = 0;i<10;i++) { // 在主线程中运行for循环
System.out.println(name+",i="+i);
}
}
}
代码如下(输出):
main,i=0
main,i=1
Thread-0,i=0
main,i=2
Thread-0,i=1
main,i=3
Thread-0,i=2
Thread-0,i=3
Thread-0,i=4
Thread-0,i=5
Thread-0,i=6
Thread-0,i=7
Thread-0,i=8
Thread-0,i=9
Thread-0,i=10
Thread-0,i=11
Thread-0,i=12
Thread-0,i=13
Thread-0,i=14
Thread-0,i=15
Thread-0,i=16
Thread-0,i=17
Thread-0,i=18
Thread-0,i=19
Thread-0,i=20
Thread-0,i=21
Thread-0,i=22
Thread-0,i=23
Thread-0,i=24
Thread-0,i=25
Thread-0,i=26
Thread-0,i=27
Thread-0,i=28
Thread-0,i=29
Thread-0,i=30
Thread-0,i=31
Thread-0,i=32
Thread-0,i=33
main,i=4
main,i=5
main,i=6
main,i=7
main,i=8
main,i=9
Thread-0,i=34
Thread-0,i=35
总结
其实看着输出这么一会有主线程的一会有守护线程的是因为线程运行的随机性,谁抢到就谁运行,但是可以看出这里面我故意将守护线程写为死循环,就是让大家明白主线程打完10个int数之后停止了,那么它的守护线程也因该在主线程之后停止,这个例子就说的这个意义。