0

0

深入理解Java中的守护线程(Daemon)_主线程退出后守护线程的行为

P粉602998670

P粉602998670

发布时间:2026-02-14 15:29:02

|

483人浏览过

|

来源于php中文网

原创

守护线程会在主线程退出时被强制终止,不保证执行完;jvm 仅等待非守护线程结束,守护线程可能被立即杀死,不执行 finally、shutdown hooks 或资源释放逻辑。

深入理解java中的守护线程(daemon)_主线程退出后守护线程的行为

守护线程会在主线程退出时被强制终止,不保证执行完

Java 中的 Thread 设置为守护线程后,JVM 会把它当作“辅助角色”——只要所有非守护线程(包括 main 线程)都结束了,JVM 就直接退出,不管守护线程正在干啥。它不会等 run() 执行完,也不会触发 finally 块,更不会调用 shutdown hooks

常见错误现象:
• 启动一个守护线程去写日志、刷缓存或发送心跳,结果程序一闪就退出,文件没写完、网络请求根本没发出去
• 在守护线程里加了 System.out.println("done")finally { System.out.println("cleanup") },但什么都没打印

  • 必须在 start() 之前调用 setDaemon(true),否则抛 IllegalThreadStateException
  • 主线程 sleep 或手动 join() 守护线程是常见补救手段,但本质是“不让 JVM 退出”,不是“让守护线程安全结束”
  • main 线程本身默认是非守护的;一旦它跑完 main() 方法体,就算没有显式调用 System.exit(),JVM 也会开始收尾

如何判断一个线程是不是守护线程

运行时用 isDaemon() 查,但要注意:这个值只反映创建后的状态,不能反推行为。比如你看到 thread.isDaemon() == true,只能说明它被设过守护,不代表它当前一定还在跑——可能已经被 JVM 杀掉了。

  • 调试时别只看 isDaemon(),配合 getState() 观察是否已进入 TERMINATED
  • 不要在守护线程里依赖 isDaemon() 做逻辑分支,它和“是否还活着”没有因果关系
  • 线程池里的工作线程默认继承创建它的线程的守护状态,所以 Executors.newCachedThreadPool() 创建的池,若在守护线程里调用,整个池都可能是守护的(容易踩坑)

守护线程适合做什么,不适合做什么

适合做无状态、可中断、不涉及资源释放的后台任务:比如定时采样 GC 数据、轮询某个标志位、维持连接保活(前提是上层协议允许突然断连)。

Windsurf
Windsurf

Codeium团队打造的AI编程助手

下载

立即学习Java免费学习笔记(深入)”;

不适合做任何需要可靠完成的事:比如关闭数据库连接、删除临时文件、提交事务、发送关键告警。

  • 适合:new Thread(() -> { while (!shutdown) { logStats(); Thread.sleep(5000); } }).setDaemon(true);
  • 不适合:new Thread(() -> { try (FileWriter w = new FileWriter("log.txt")) { w.write("final msg"); } }).setDaemon(true); —— try-with-resources 根本不会执行
  • 如果要用线程做清理,必须是非守护线程 + 显式生命周期管理(如 Runtime.addShutdownHook()

JVM 退出时机比想象中更早

很多人以为“主线程退出=main方法执行完”,其实 JVM 是看“有没有非守护线程在运行”。哪怕你在 main() 最后一行启动了一个非守护线程并立即 return,JVM 也会继续运行,直到那个线程也结束。

  • System.exit(0) 会立刻终止所有线程,包括非守护线程,此时守护线程的行为无关紧要
  • 使用 java -Dfile.encoding=UTF-8 MyApp 这类参数不影响守护线程语义,但会影响其内部 I/O 行为(比如日志乱码),容易误判为“线程挂了”
  • 在容器环境(如 Docker)中,如果主进程是 Java 应用,且它只靠守护线程维持,容器可能秒退——因为 JVM 认为自己没事可干了

最常被忽略的一点:守护线程的 run() 方法里哪怕只有两行代码,也可能只执行了第一行就被终结。它没有“最后一点时间”的概念。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
while的用法
while的用法

while的用法是“while 条件: 代码块”,条件是一个表达式,当条件为真时,执行代码块,然后再次判断条件是否为真,如果为真则继续执行代码块,直到条件为假为止。本专题为大家提供while相关的文章、下载、课程内容,供大家免费下载体验。

102

2023.09.25

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

673

2023.08.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

673

2023.08.10

Java 并发编程高级实践
Java 并发编程高级实践

本专题深入讲解 Java 在高并发开发中的核心技术,涵盖线程模型、Thread 与 Runnable、Lock 与 synchronized、原子类、并发容器、线程池(Executor 框架)、阻塞队列、并发工具类(CountDownLatch、Semaphore)、以及高并发系统设计中的关键策略。通过实战案例帮助学习者全面掌握构建高性能并发应用的工程能力。

93

2025.12.01

k8s和docker区别
k8s和docker区别

k8s和docker区别有抽象层次不同、管理范围不同、功能不同、应用程序生命周期管理不同、缩放能力不同、高可用性等等区别。本专题为大家提供k8s和docker区别相关的各种文章、以及下载和课程。

265

2023.07.24

docker进入容器的方法有哪些
docker进入容器的方法有哪些

docker进入容器的方法:1. Docker exec;2. Docker attach;3. Docker run --interactive --tty;4. Docker ps -a;5. 使用 Docker Compose。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

511

2024.04.08

docker容器无法访问外部网络怎么办
docker容器无法访问外部网络怎么办

docker 容器无法访问外部网络的原因和解决方法:配置 nat 端口映射以将容器端口映射到主机端口。根据主机兼容性选择正确的网络驱动(如 host 或 overlay)。允许容器端口通过主机的防火墙。配置容器的正确 dns 服务器。选择正确的容器网络模式。排除主机网络问题,如防火墙或连接问题。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

409

2024.04.08

docker镜像有什么用
docker镜像有什么用

docker 镜像是预构建的软件组件,用途广泛,包括:应用程序部署:简化部署,提高移植性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

446

2024.04.08

pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法
pixiv网页版官网登录与阅读指南_pixiv官网直达入口与在线访问方法

本专题系统整理pixiv网页版官网入口及登录访问方式,涵盖官网登录页面直达路径、在线阅读入口及快速进入方法说明,帮助用户高效找到pixiv官方网站,实现便捷、安全的网页端浏览与账号登录体验。

23

2026.02.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
Kotlin 教程
Kotlin 教程

共23课时 | 3.6万人学习

C# 教程
C# 教程

共94课时 | 9.4万人学习

Java 教程
Java 教程

共578课时 | 65.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号