Hello 大家好,我是小米,一名在 Java 世界里摸爬滚打了快十年的老程序猿,热衷分享技术与面试经验,尤其是在社招场上,那可是打怪升级的真实战场。
今天的这篇文章,灵感来自上周我给一个同事辅导社招面试时的经历。他面试遇到一个很冷门但也很“有味道”的题目——什么是线程组(ThreadGroup)?为什么在 Java 中现在不推荐使用?
听起来是不是很基础?但它真的是一个不小心就会答错的“陷阱题”!
而且,面试官问完后,居然追问了两个深入问题:
- 线程组和 Executor 框架的关系是什么?
- 如果你要用线程组来实现线程管理,会遇到什么坑?
啧啧啧,这不是挖了个思维陷阱吗?于是我当场给他讲了一个故事。
这就分享给你。
从一个线程泄漏的线上事故讲起
时间回到 2021 年夏天,那时候我在一家中型互联网公司做系统性能优化。某天凌晨,我们的核心服务在高峰期突然线程耗尽,压测通过的接口居然直接 504。
我们火速排查,发现是某个业务模块开启了一堆线程来处理图片压缩,但没有做任何线程回收的操作,导致系统线程池外的“野线程”疯狂增长。更离谱的是,这段代码还用了 ThreadGroup 来管理这些线程,美其名曰“方便查看”。