[Java并发]守护线程
守护线程和普通线程的最大区别是守护线程会在主线程结束后退出,但是普通线程在主线程结束后不会退出。
普通线程的执行
import java.sql.Time;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
public static void main(String[] args) throws InterruptedException {
System.out.println("线程开始运行");
new Thread(new Runnable() {
@Override
public void run() {
while(true){
try {
System.out.println("非守护线程正在运行");
Thread.sleep(1000);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
}
}
}).start();
System.out.println("主线程运行完成");
}
}
线程开始运行
主线程运行完成
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
非守护线程正在运行
守护线程的执行
import java.sql.Time;
import java.util.concurrent.ExecutorService;
import java.util.concurrent.Executors;
public class Main {
public static void main(String[] args) throws InterruptedException {
System.out.println("线程开始运行");
Thread thread = new Thread(new Runnable() {
@Override
public void run() {
while(true){
try {
System.out.println("非守护线程正在运行");
Thread.sleep(1000);
} catch (InterruptedException e) {
throw new RuntimeException(e);
}
}
}
});
thread.setDaemon(true);
thread.start();
System.out.println("主线程运行完成");
}
}
线程开始运行
主线程运行完成
非守护线程正在运行
如果 JVM 中没有一个正在运行的非守护线程,这个时候,JVM 会退出。换句话说,守护线程拥有自动结束自己生命周期的特性,而非守护线程不具备这个特点。
JVM 中的垃圾回收线程就是典型的守护线程,如果说不具备该特性,会发生什么呢?
当 JVM 要退出时,由于垃圾回收线程还在运行着,导致程序无法退出,这就很尴尬了!!!由此可见,守护线程的重要性了。
通常来说,守护线程经常被用来执行一些后台任务,但是呢,你又希望在程序退出时,或者说 JVM 退出时,线程能够自动关闭,此时,守护线程是你的首选。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义