25年11月腾讯 Java实习 二面

#JAVA##JAVA面经##JAVA内推#

1. WebSocket 心跳机制的核心作用是什么?

思路 核心是检测连接存活状态,避免长连接被中间件/防火墙断开,同时处理断线重连。

回答示例

WebSocket 心跳机制的核心作用是保活+断线检测

  1. 维持连接:WebSocket 长连接若长时间无数据交互,会被防火墙、网关或服务器主动断开,心跳包(客户端/服务端定时发送的空消息/特定指令)能模拟数据交互,让连接保持活跃;
  2. 断线检测:若发送心跳包后超时未收到响应,可判定连接已断开,触发断线重连逻辑,保证通信的连续性;
  3. 资源释放:服务端可通过心跳超时识别无效连接,主动释放资源,避免连接泄漏。

2. HTTP 长连接在服务端如何管理空闲连接?

思路 核心是设置空闲超时时间,配合连接池、最大连接数限制,避免空闲连接占用资源。

回答示例

服务端管理 HTTP 长连接的核心是超时控制+资源限制

  1. 设置空闲超时时间:通过 Keep-Alive: timeout=xx 响应头,指定连接空闲 xx 秒后自动断开;Tomcat/Nginx 等中间件也可配置全局超时(如 Nginx 的 keepalive_timeout);
  2. 连接池限制:维护长连接池,设置最大连接数,超出则拒绝新连接或关闭最久空闲连接;
  3. 主动回收:定时扫描空闲连接,对超时的连接执行 close(),释放文件描述符和内存资源;
  4. 监控告警:统计空闲连接数、超时次数,避免连接数过多导致服务器资源耗尽。

3. G1 收集器如何实现可预期停顿时间?

思路 核心是基于 Region 分区+停顿预测模型,通过“设置停顿目标+选择回收收益最高的 Region”控制停顿时间。

回答示例

G1 实现可预期停顿的核心是分区管理+收益优先回收

  1. Region 内存分区:将堆划分为多个大小相等的 Region,回收时以 Region 为单位,而非整代回收;
  2. 停顿预测模型:G1 会记录每个 Region 的回收耗时和可回收内存(收益),维护“收益-耗时”优先级列表;
  3. 目标驱动回收:用户设置停顿目标(如 -XX:MaxGCPauseMillis=200),G1 在回收前计算:选择哪些 Region 组合,能在目标时间内回收最多内存;
  4. 增量回收:每次只回收部分 Region,而非一次性回收全部垃圾,确保单次停顿不超预期。

简单说:G1 是“按需回收、见好就收”,而非“一次性清完”,因此能精准控制停顿。

4. ThreadLocal 内存泄漏的根本原因是什么?

思路 核心是 ThreadLocalMap 的 Entry 结构:key 是弱引用,value 是强引用,线程存活时 value 无法被 GC 回收。

回答示例

ThreadLocal 内存泄漏的根本原因是引用类型不匹配导致的强引用持有

  1. ThreadLocalMap 的 Entry 中,key 是对 ThreadLocal 的弱引用(GC 时会被回收),但 value 是对实际数据的强引用
  2. 当 ThreadLocal 被回收(key 为 null),但线程仍存活(如线程池核心线程),Entry 中的 value 因强引用无法被 GC;
  3. 这些无效的 value 会一直占用内存,最终导致内存泄漏,严重时触发 OOM。

补充:线程结束时会释放 ThreadLocalMap,因此普通线程不会泄漏,但线程池的常驻线程是泄漏的重灾区。

5. 快排三数取中优化解决了什么问题?

思路 解决基准值选择不当导致的最坏时间复杂度(O(n²)),让快排更稳定。

回答示例

快排三数取中优化的核心是避免基准值选到极值,解决最坏时间复杂度问题

  1. 原始快排通常选第一个/最后一个元素作为基准,若数组有序(如升序/降序),基准会是最小值/最大值,导致分区极不均衡(一边空、一边全量),时间复杂度退化为 O(n²);
  2. 三数取中:选取数组首、尾、中间三个位置的元素,取中位数作为基准,能最大程度保证基准值处于数组中间,让分区更均衡;
  3. 优化效果:即使面对有序数组,也能保证分区效率,快排时间复杂度稳定在 O(n log n),避免极端低效场景。

6. RabbitMQ 镜像队列的作用是什么?

思路 核心是队列高可用,避免单节点故障导致队列不可用/消息丢失。

回答示例

RabbitMQ 镜像队列的核心作用是保证队列的高可用

  1. 镜像队列会将主队列(master)的消息同步到多个从队列(slave),分布在不

剩余60%内容,订阅专栏后可继续查看/也可单篇购买

本专栏在精不在多,内容分为八股文、大厂真实面经,面试通过后将offer和面试题私发给我,可退还专栏的收益部分费用。欢迎大家共建专栏

全部评论
本专栏在精不在多,内容分为八股文、大厂真实面经,面试通过后将offer和面试题私发给我,可退还专栏的收益部分费用。欢迎大家共建专栏。 专栏目录https://www.nowcoder.com/share/jump/1772859327707
点赞 回复 分享
发布于 昨天 21:19 广东

相关推荐

点赞 评论 收藏
分享
03-07 01:06
门头沟学院 Java
一.实习问题1.日志追踪功能的核心标识以及传递方式是怎样的。2.多层关系挖掘的业务逻辑是怎么样的,资源的依赖关系是怎么样的,关系是怎么保存的。3.百万级数据导出的业务,导出的什么数据。二.项目问题1.抽象规则树当中都抽象了哪些规则,中间想要加规则可以加吗,怎么加。2.关于人群标签这块,如何去区分什么样的人群应该添加什么样的标签。3.关于人群标签这块,如果相对一些人的标签信息进行增删改查操作如何操作呢。4.关于redis的发布订阅,用来订阅什么。5.关于限流这块,限流的范围是什么。6.关于交易规则链路,核心的链路都是什么,即哪些节点,做了哪些规则校验。7.关于交易规则链路,如何想要添加一个新规则,如何将它快速接入呢。8.关于执行过程中会出现中断跳过的情况吗,如果出现了怎么办。9.关于拼团成功这样的消息提示有做推送的机制吗。10.下单支付成功后,会进行同步操作还是异步操作呢。11.关于库存的并发是怎么控制的。12.关于库存这块如果仅使用Mysql库存>0判断,为何还需要其他类似于分布式事务机制这样的操作来解决呢。三.八股问题1.springboot自定义配置这样的机制,自动配置的流程是什么样的,SPI机制。2.SPI机制有什么用。3.springboot如何实现一个start。4.redis的持久化机制有哪几种。5.redis的过期删除策略。6.redis实现分布式锁,用到了哪些命令。7.mysql慢查询分析如何分析,explain中的type字段有哪些类型。8.索引失效有哪些。9.事务的隔离界别有哪些,有哪些并发问题。10.threadLocal的使用场景。11.线程池的核心参数有哪些。12.拒绝策略有哪几种,平时使用哪一个。没想到小小厂还有二面。
发面经攒人品
点赞 评论 收藏
分享
评论
1
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务