细说多线程之Thread VS Runnable 03
守护线程
Java线程有两类
- 用户线程
运行在前台,执行具体的任务.例:程序的主线程、连接网络的子线程等 - 守护线程
运行在后台,为其他前台线程服务
特点:一旦所有用户线程都结束运行,守护线程会随JVM一起结束工作
应用: 数据库连接池中的检测线程 , JVM虚拟机启动后的检测线程
最常见的守护线程:垃圾回收线程
- 用户线程
如何设置守护线程
通过调用Thread类的setDaemeon(true)方法来设置当前的线程为守护线程- 使用守护线程的注意事项
- setDaemeon(true)必须在start()方法之前调用,否则会抛出IllegalThreadStateException异常
- 在守护线程中产生的新线程也是守护线程
- 简单示例
守护线程不断往文件中写数据,主线程阻塞等待来自键盘的输入,一旦主线程获取到了键盘的输入,阻塞接触,主线程继续进行,一旦主线程结束,用户线程结束运行,而守护线程会随JVM一起结束,不管读写操作是否结束
class DaemonThread implements Runnable {
@Override
public void run() {
System.out.println("进入守护线程" + Thread.currentThread().getName());
try {
writeToFile();
} catch (Exception e) {
e.printStackTrace();
}
System.out.println("退出守护线程" + Thread.currentThread().getName());
}
private void writeToFile() throws Exception {
File filename = new File("D:" + File.separator + "daemon.txt");
OutputStream os = new FileOutputStream(filename, true);
int count = 0;// 每写一次数据,count++;
while (count < 999) {
os.write(("\r\nword" + count).getBytes());
System.out.println("守护线程" + Thread.currentThread().getName() + "向文件中写入了word" + count++);
Thread.sleep(1000);
}
}
}
public class DaemonThreadDemo {
public static void main(String[] args) {
System.out.println("进入主线程" + Thread.currentThread().getName());
DaemonThread daemonThread = new DaemonThread();
Thread thread = new Thread(daemonThread);
thread.setDaemon(true);
thread.start();
Scanner input = new Scanner(System.in);
input.next();
System.out.println("退出主线程" + Thread.currentThread().getName());
}
}