面试官: 谈谈什么是守护线程以及作用 ?

文章首发自微信公众号: 小哈学Java

个人网站: https://www.exception.site/java-concurrency/java-concurrency-daemon-thread

目录

一、什么是守护线程

二、守护线程的作用及应用场景

三、总结

一、什么是守护线程

守护线程相对于正常线程来说,是比较特殊的一类线程,那么它特殊在哪里呢?别急,在了解它之前,我们需要知道一个问题,那就是:

JVM 程序在什么情况下能够正常退出?

The Java Virtual Machine exits when the only threads running are all daemon threads.

上面这句话来自 JDK 官方文档,意思是:

当 JVM 中不存在任何一个正在运行的非守护线程时,则 JVM 进程即会退出。

理解起来有点拗口,看完下面的代码你就懂了 。^_^

  • ①:创建一个非守护线程;
  • ②:模拟非守护线程不退出的情况;
  • ③:启动线程;
  • ④:主线程即将退出;

运行这段代码,猜猜看,JVM 进程是否能够正常退出呢?

可以看到因为有一个非守护线程一直在后台运行着,JVM 无法正常退出。那么,如果说正在运行的是个守护线程,结果又会怎么样呢?

  • ①:添加一个钩子(Hook)线程, 用来监听 JVM 退出,并输出日志;

关于 Hook (钩子) 线程可以看我之前的文章:《Java 多线程之 Hook (钩子) 线程》

  • ②:通过 setDaemon(true)将该线程为守护线程;

再次运行代码,瞅瞅效果:

可以看到,当主线程退出时,JVM 会随之退出运行,守护线程同时也会被回收,即使你里面是个死循环也不碍事。

二、守护线程的作用及应用场景

通过上面的示例代码,相信你已经了解了守护线程和普通线程之间的区别,那么,我们来讨论一下为什么需要守护线程,以及何时使用,它的应用场景是什么?

上面,我们已经知道了,如果 JVM 中没有一个正在运行的非守护线程,这个时候,JVM 会退出。换句话说,守护线程拥有自动结束自己生命周期的特性,而非守护线程不具备这个特点

JVM 中的垃圾回收线程就是典型的守护线程,如果说不具备该特性,会发生什么呢?

当 JVM 要退出时,由于垃圾回收线程还在运行着,导致程序无法退出,这就很尴尬了!!!由此可见,守护线程的重要性了。

通常来说,守护线程经常被用来执行一些后台任务,但是呢,你又希望在程序退出时,或者说 JVM 退出时,线程能够自动关闭,此时,守护线程是你的首选。

三、总结

本文中,我们学习了什么是守护线程,通过示例代码了解了守护线程的特性,以及守护线程的作用,和应用场景。最后,如果看完此文有所收获,不妨点个关注哈。

四、GitHub 示例源码

https://github.com/weiwosuoai/java-concurrent-tutorial/tree/master/DaemonThread

赠送 | 面试&学习福利资源

最近在网上发现一个不错的 PDF 资源《Java 核心面试知识.pdf》分享给大家,不光是面试,学习,你都值得拥有!!!

获取方式: 关注公众号: 小哈学Java, 后台回复 资源,既可获取资源链接,下面是目录以及部分截图:

重要的事情说两遍,获取方式: 关注公众号: 小哈学Java, 后台回复 资源,既可获取资源链接 !!!

欢迎关注微信公众号: 小哈学Java

原文地址:https://www.cnblogs.com/quanxiaoha/p/10731361.html

时间: 2024-11-05 20:33:11

面试官: 谈谈什么是守护线程以及作用 ?的相关文章

面试官:你分析过线程池源码吗?

线程池源码也是面试经常被提问到的点,我会将全局源码做一分析,然后告诉你面试考啥,怎么答. 为什么要用线程池? 简洁的答两点就行. 降低系统资源消耗. 提高线程可控性. 如何创建使用线程池? JDK8提供了五种创建线程池的方法: 1.创建一个定长线程池,可控制线程最大并发数,超出的线程会在队列中等待. 1 public static ExecutorService newFixedThreadPool(int nThreads) { 2 return new ThreadPoolExecutor(

面试官 :“谈谈Spring中都用到了哪些设计模式?”

JDK 中用到了那些设计模式?Spring 中用到了那些设计模式?这两个问题,在面试中比较常见.我在网上搜索了一下关于 Spring 中设计模式的讲解几乎都是千篇一律,而且大部分都年代久远.所以,花了几天时间自己总结了一下,由于我的个人能力有限,文中如有任何错误各位都可以指出.另外,文章篇幅有限,对于设计模式以及一些源码的解读我只是一笔带过,这篇文章的主要目的是回顾一下 Spring 中的常见的设计模式. Design Patterns(设计模式) 表示面向对象软件开发中最好的计算机编程实践.

面试官: 什么是 Hook (钩子) 线程以及应用场景?

一.Hook 线程介绍 通常情况下,我们可以向应用程序注入一个或多个 Hook (钩子) 线程,这样,在程序即将退出的时候,也就是 JVM 程序即将退出的时候,Hook 线程就会被启动执行. 先看一段示例代码: ①:为应用程序注入一个钩子(Hook)线程,线程中,打印了相关日志,包括正在运行以及退出的日志:②:再次注入一个同样逻辑的钩子(Hook)线程:③:主线程执行结束,打印日志: 运行这段代码,来验证一下: 从打印日志看到,当主线程执行结束,也就是 JVM 进程即将退出的时候,注入的两个 H

【面试】如果你这样回答“什么是线程安全”,面试官都会对你刮目相看

不是线程的安全 面试官问:"什么是线程安全",如果你不能很好的回答,那就请往下看吧. 论语中有句话叫"学而优则仕",相信很多人都觉得是"学习好了可以做官".然而,这样理解却是错的.切记望文生义. 同理,"线程安全"也不是指线程的安全,而是指内存的安全.为什么如此说呢?这和操作系统有关. 目前主流操作系统都是多任务的,即多个进程同时运行.为了保证安全,每个进程只能访问分配给自己的内存空间,而不能访问别的进程的,这是由操作系统保障

白话JAVA守护线程

OneCoder(苦逼Coder)原创,转载请务必注明出处: http://www.coderli.com/archives/daemon-thread-plain-words/ 关于“白话”:偶然想到的词,也许有一天能成为一个系列.目的就是用简洁,明快的语言来告诉您,我所知道的一切. Java中的线程分两类,用户线程和守护线程. Thread commonThread = new Thread("Common Thread"); 这样就是用户线程. Thread daemonThre

Java 多线程(四)之守护线程(Daemon)

定义 Java 中有两种线程: 一种是用户线程(User Thread),一种是守护线程(Daemon Thread). 守护线程是一种特殊的线程, 它的特殊有"陪伴"的含义, 当线程中不存在非守护线程时, 则守护线程自动销毁. 垃圾回收线程就是一种守护线程, 当线程中没有非守护线程了, 则垃圾回收线程就会自动销毁. 因此, 守护线程的作用就是为其他非守护线程的线程服务, 当非守护线程不存在时, 其自然就没有存在的必要了. 如何创建 创建过程与一般的线程一样, 只需要在创建完之后调用如

Android开发面试经——5.常见面试官提问Android题(更新中...)

关注finddreams博客: http://blog.csdn.net/finddreams/article/details/44513579 一般的面试流程是笔试完就接着是面试了,面试时技术经理会问你一些你工作中遇到的Android方面的问题,谈谈你所做的项目,和在项目中所扮演的角色.今天我就给大家整理一些,面试中常见的面试官提的一些问题? 1.要做一个尽可能流畅的ListView,你平时在工作中如何进行优化的? ①Item布局,层级越少越好,使用hierarchyview工具查看优化. ②

一个资深java面试官的“面试心得”

在公司当技术面试官几年间,从应届生到工作十几年的应聘者都遇到过.先表达一下我自己对面试的观点: 1.笔试.面试去评价一个人肯定是不够准确的,了解一个人最准确的方式就是“路遥知马力,日久见人心”.通过一.二个小时内的做题.交流,只是没有其他办法下进行的无奈之举,所以通过了面试不代表有多成功,没通过也不代表有多失败.2.好的面试官本身交谈的时候就不应当把自己一个居高临下的角色上,应当把自己和应聘者当做两个做技术的人平等的交流,把自己当作权威往往就会受到观点的角度.语言表达.工作领域的惯性的制约.3.

Android开发面试经——6.常见面试官提问Android题②(更新中...)

版权声明:本文为寻梦-finddreams原创文章,请关注:http://blog.csdn.net/finddreams 关注finddreams博客:http://blog.csdn.net/finddreams/article/details/44560061 1.HttpURLConnection和HttpClient他们各自的优缺点是什么? HttpUrlConnection 在 2.3 以前的版本是有 bug 的,所以之前的版本推荐使用 HttpClient,但是 google 现在