当前位置: 首页 > news >正文

2025年Java后端秋招面试的高频八股文+场景题

一、Java核心八股文(必背)

1. Java基础
  1. HashMap vs ConcurrentHashMap

    • HashMap:非线程安全,JDK1.8后采用数组+链表/红黑树,扩容可能死循环(JDK1.7)。

    • ConcurrentHashMap:JDK1.8改用CAS+synchronized优化锁粒度,分段锁淘汰。

  2. synchronized vs ReentrantLock

    • synchronized:JVM内置锁,非公平锁,不可中断。

    • ReentrantLock:支持公平锁、可中断、Condition条件队列。

  3. volatile作用与局限性

    • 保证可见性(强制主存读取)和有序性(禁止指令重排序),但不保证原子性(如i++AtomicInteger)。

  4. JVM内存模型

    • 线程私有:虚拟机栈、本地方法栈、程序计数器。

    • 线程共享:堆、方法区(JDK1.8后为元空间)。

  5. G1垃圾回收器特点

    • Region分区、可预测停顿、适合大内存应用。


二、高并发与分布式系统

1. 并发编程
  1. 线程池参数设置

    • corePoolSize(核心线程数)、maxPoolSize(最大线程数)、workQueue(任务队列)、拒绝策略18。

    • IO密集型CPU核心数 * 2CPU密集型CPU核心数 + 1

  2. AQS原理

    • 核心:state(资源状态)+ CLH队列(线程排队),实现类如ReentrantLockCountDownLatch

  3. 分布式锁方案

    • Redis(SETNX + RedLock)、ZooKeeper(临时节点 + Watch机制)。

2. 分布式场景题
  1. 如何设计秒杀系统?

    • 分层削峰:Nginx限流 → Redis预减库存(Lua脚本保证原子性)→ 消息队列异步处理。

    • 热点隔离:独立Redis集群处理秒杀商品。

  2. CAP理论应用

    • 支付系统侧重CP(一致性+分区容错性),社交系统可能选择AP。


三、数据库与缓存优化

1. MySQL高频考点
  1. 十亿级数据分页优化

    • ES search_after(深度分页)、覆盖索引 + 禁止跳页(LIMIT优化)。

  2. 索引失效场景

    • LIKE '%xx'、函数计算、OR条件、隐式类型转换。

  3. MVCC实现原理

    • ReadView + Undo Log版本链,解决不可重复读 & 幻读。

2. Redis实战
  1. 缓存一致性方案

    • 延迟双删(先删缓存→更新DB→再删缓存)、订阅Binlog(Canal监听变更)。

  2. 缓存雪崩预防

    • 随机过期时间 + 多级缓存(本地→Redis→DB)+ 熔断降级(Sentinel)。


四、微服务与系统设计

1. 微服务核心问题
  1. Spring Boot自动配置原理

    • @EnableAutoConfiguration + META-INF/spring.factories + 条件注解(@Conditional)。

  2. 服务熔断策略

    • Sentinel动态调整阈值(基于慢调用比例触发降级)。

2. 系统设计题
  1. 设计一个高可用支付系统

    • 一致性:TCC事务 + 对账机制。

    • 容灾:同城多活(数据同步:MySQL Binlog + Kafka)。

  2. 如何实现全链路灰度发布?

    • 流量标记(Header传递) + Service Mesh(Istio动态路由)。


五、2025年新趋势(加分项)

  1. 云原生技术

    • K8s在大促中的应用(HPA自动扩缩容)、Serverless(适合定时任务/日志分析)。

  2. 大模型与编程结合

    • 使用AI辅助代码生成(如GitHub Copilot),但需关注代码安全审查。


六、面试技巧

  1. 项目深挖

    • 用STAR法则描述项目:背景(S)、任务(T)、行动(A)、结果(R)。

    • 示例:“通过Redis集群优化,将商品查询RT从200ms降至50ms”

  2. 避坑指南

    • 避免提及不熟悉的技术(如提到Kafka却说不清ISR机制)。

  3. 算法准备

    • LeetCode中等难度高频题:二叉树遍历、DFS/BFS、动态规划。


 

 

http://www.lryc.cn/news/590854.html

相关文章:

  • Linux C 进程基本操作
  • 【Elasticsearch】Elasticsearch 快照恢复 API 参数详解
  • Git 多人协作实战:从基础操作到分支管理全流程记录
  • 关于el-table异步获取数据渲染动态列数据赋值列数据渲染时title高度异常闪过问题
  • vue3+ts+elementui-表格根据相同值合并
  • Linux之Zabbix分布式监控篇(二)
  • 算法竞赛备赛——【图论】求最短路径——Floyd算法
  • 【华为机试】122. 买卖股票的最佳时机 II
  • React 学习(4)
  • 研发知识系统选型实战:从 Notion 到 Gitee Wiki 的迭代经验
  • STM32 DMA通信详解
  • 求解偏微分方程的傅里叶积分解
  • ThreadLocal使用详解-从源码层面分析
  • Python 网络爬虫 —— requests 库和网页源代码
  • 智能体开发工具链全景图:IDE、调试器与监控平台
  • Fair-code介绍(Fair code)(一套新型软件模型:旨在“开源”“商业可持续性”中找到平衡)
  • Windows 11清理C盘方法大全:磁盘清理/禁用休眠/系统还原点/优化大师使用教程
  • Android默认背光亮度配置说明
  • 纯前端html实现图片坐标与尺寸(XY坐标及宽高)获取
  • SegNet:一种用于图像分割的深度卷积编码器解码器架构
  • RocketMQ 高可用集群架构与一致性机制解析
  • 【3D目标检测】Livox Tele-15采集的.lvx数据转.bag再转.pcd
  • 鲍威尔去留风波的AI量化解析:基于多模态数据驱动的金融市场脉冲响应研究
  • 达梦数据守护集群搭建(1主1实时备库1同步备库1异步备库)
  • 时序数据库选型指南 —— 为什么选择 Apache IoTDB?
  • javaweb学习开发代码_HTML-CSS-JS
  • Java面试(基础篇) - 第二篇!
  • slot=“trigger“ 覆盖了组件内部的 ref=“trigger“【详细来龙去脉版 5min】
  • Web开发 01
  • Python的“__name__“属性