25年11月腾讯 Java实习 二面
#JAVA##JAVA面经##JAVA内推#
1. WebSocket 心跳机制的核心作用是什么?
思路 核心是检测连接存活状态,避免长连接被中间件/防火墙断开,同时处理断线重连。
回答示例
WebSocket 心跳机制的核心作用是保活+断线检测:
- 维持连接:WebSocket 长连接若长时间无数据交互,会被防火墙、网关或服务器主动断开,心跳包(客户端/服务端定时发送的空消息/特定指令)能模拟数据交互,让连接保持活跃;
- 断线检测:若发送心跳包后超时未收到响应,可判定连接已断开,触发断线重连逻辑,保证通信的连续性;
- 资源释放:服务端可通过心跳超时识别无效连接,主动释放资源,避免连接泄漏。
2. HTTP 长连接在服务端如何管理空闲连接?
思路 核心是设置空闲超时时间,配合连接池、最大连接数限制,避免空闲连接占用资源。
回答示例
服务端管理 HTTP 长连接的核心是超时控制+资源限制:
- 设置空闲超时时间:通过
Keep-Alive: timeout=xx响应头,指定连接空闲 xx 秒后自动断开;Tomcat/Nginx 等中间件也可配置全局超时(如 Nginx 的keepalive_timeout); - 连接池限制:维护长连接池,设置最大连接数,超出则拒绝新连接或关闭最久空闲连接;
- 主动回收:定时扫描空闲连接,对超时的连接执行
close(),释放文件描述符和内存资源; - 监控告警:统计空闲连接数、超时次数,避免连接数过多导致服务器资源耗尽。
3. G1 收集器如何实现可预期停顿时间?
思路 核心是基于 Region 分区+停顿预测模型,通过“设置停顿目标+选择回收收益最高的 Region”控制停顿时间。
回答示例
G1 实现可预期停顿的核心是分区管理+收益优先回收:
- Region 内存分区:将堆划分为多个大小相等的 Region,回收时以 Region 为单位,而非整代回收;
- 停顿预测模型:G1 会记录每个 Region 的回收耗时和可回收内存(收益),维护“收益-耗时”优先级列表;
- 目标驱动回收:用户设置停顿目标(如
-XX:MaxGCPauseMillis=200),G1 在回收前计算:选择哪些 Region 组合,能在目标时间内回收最多内存; - 增量回收:每次只回收部分 Region,而非一次性回收全部垃圾,确保单次停顿不超预期。
简单说:G1 是“按需回收、见好就收”,而非“一次性清完”,因此能精准控制停顿。
4. ThreadLocal 内存泄漏的根本原因是什么?
思路 核心是 ThreadLocalMap 的 Entry 结构:key 是弱引用,value 是强引用,线程存活时 value 无法被 GC 回收。
回答示例
ThreadLocal 内存泄漏的根本原因是引用类型不匹配导致的强引用持有:
- ThreadLocalMap 的 Entry 中,key 是对 ThreadLocal 的弱引用(GC 时会被回收),但 value 是对实际数据的强引用;
- 当 ThreadLocal 被回收(key 为 null),但线程仍存活(如线程池核心线程),Entry 中的 value 因强引用无法被 GC;
- 这些无效的 value 会一直占用内存,最终导致内存泄漏,严重时触发 OOM。
补充:线程结束时会释放 ThreadLocalMap,因此普通线程不会泄漏,但线程池的常驻线程是泄漏的重灾区。
5. 快排三数取中优化解决了什么问题?
思路 解决基准值选择不当导致的最坏时间复杂度(O(n²)),让快排更稳定。
回答示例
快排三数取中优化的核心是避免基准值选到极值,解决最坏时间复杂度问题:
- 原始快排通常选第一个/最后一个元素作为基准,若数组有序(如升序/降序),基准会是最小值/最大值,导致分区极不均衡(一边空、一边全量),时间复杂度退化为 O(n²);
- 三数取中:选取数组首、尾、中间三个位置的元素,取中位数作为基准,能最大程度保证基准值处于数组中间,让分区更均衡;
- 优化效果:即使面对有序数组,也能保证分区效率,快排时间复杂度稳定在 O(n log n),避免极端低效场景。
6. RabbitMQ 镜像队列的作用是什么?
思路 核心是队列高可用,避免单节点故障导致队列不可用/消息丢失。
回答示例
RabbitMQ 镜像队列的核心作用是保证队列的高可用:
- 镜像队列会将主队列(master)的消息同步到多个从队列(slave),分布在不
剩余60%内容,订阅专栏后可继续查看/也可单篇购买
本专栏在精不在多,内容分为八股文、大厂真实面经,面试通过后将offer和面试题私发给我,可退还专栏的收益部分费用。欢迎大家共建专栏
查看36道真题和解析