Java面试题及答案总结(2025版持续更新)
大家好,我是Java面试分享
最近很多小伙伴在忙着找工作,给大家整理了一份非常全面的Java面试题及答案。
涉及的内容非常全面,包含:并发编程、Nginx、Redis、Kafka、Spring、Mysql、JVM…等内容,希望对找工作的小伙伴有所帮助。
一、并发编程场景题
- 线程安全计数器
如何实现一个多线程环境下的高性能计数器?对比AtomicInteger、synchronized和LongAdder的实现和适用场景。 - 死锁模拟与解决
编写代码模拟死锁(两个线程互相持有对方需要的锁),并提出至少3种避免死锁的策略。 - 线程池任务堆积
当线程池的任务队列满了,且核心线程数已满,有哪些拒绝策略?如何自定义一个记录日志的拒绝策略? - 生产者-消费者问题
使用BlockingQueue实现生产者-消费者模型,对比ArrayBlockingQueue和LinkedBlockingQueue的性能差异。 - 并发集合的选择
高并发环境下,HashMap、ConcurrentHashMap和Collections.synchronizedMap()如何选择?为什么? - CompletableFuture链式调用
使用CompletableFuture实现“任务A执行完后异步触发任务B和任务C,B和C都完成后执行任务D”。 - ThreadLocal内存泄漏
为什么ThreadLocal可能引发内存泄漏?如何正确使用和清理? - 分布式锁的实现
如何在Java中基于Redis实现一个分布式锁?如何处理锁续期问题? - CAS的ABA问题
什么是CAS的ABA问题?如何解决(如AtomicStampedReference)? - 并发限流
如何用Semaphore或RateLimiter实现接口的QPS限流? - ForkJoinPool适用场景
什么情况下适合用ForkJoinPool而不是普通线程池?举例说明。 - volatile与缓存一致性
volatile如何保证可见性?它的底层原理(如MESI协议)是什么? - 异步回调地狱
如何用Java的异步编程(如CompletableFuture)解决回调地狱问题? - 无锁队列实现
如何基于CAS实现一个无锁队列(伪代码)? - 并发测试工具
如何用JMH测试多线程代码的性能?需要注意哪些坑?
二、Nginx场景题
- 负载均衡算法
Nginx支持哪些负载均衡算法?如何根据业务场景选择轮询、加权轮询或IP Hash? - 动静分离配置
如何配置Nginx实现动静分离(静态资源由Nginx直接返回,动态请求转发到Tomcat)? - 高并发优化
如何调整Nginx的worker_processes、worker_connections和内核参数以支持10万并发? - HTTPS配置
如何为Nginx配置HTTPS并启用HTTP/2?如何强制跳转HTTPS? - 反向代理缓存
如何配置Nginx缓存后端服务的响应?缓存失效策略如何设置? - 跨域问题解决
如何通过Nginx配置解决前端跨域问题?add_header指令如何正确使用? - 限流配置
如何用Nginx的limit_req_zone和limit_conn_zone实现IP级别的限流? - 灰度发布方案
如何通过Nginx实现基于Cookie或Header的灰度发布? - 日志切割与分析
如何配置Nginx日志按天切割?如何用awk分析访问日志中的高频IP? - WebSocket代理
如何配置Nginx反向代理WebSocket连接?需要注意哪些参数(如proxy_read_timeout)? - 防盗链配置
如何用Nginx防止其他网站盗用你的静态资源(如图片)? - URL重写
如何用rewrite规则将旧URL(如/product?id=123)重写为RESTful风格(如/product/123)? - 多域名配置
如何在一个Nginx实例中配置多个域名的虚拟主机?如何避免server_name冲突? - 性能调优
如何通过gzip压缩、sendfile和tcp_nopush优化Nginx传输性能? - 健康检查
如何配置Nginx对后端服务做主动健康检查?与K8s的Ingress健康检查有何区别?
三、Redis场景题
- 热点Key问题
如何发现和处理Redis的热点Key?有哪些解决方案(如本地缓存、分片)? - 缓存穿透/雪崩/击穿
如何解决缓存穿透(布隆过滤器)、雪崩(随机过期时间)、击穿(互斥锁)? - 分布式锁实现
如何用Redis实现分布式锁?SETNX和RedLock算法各有什么优缺点? - 持久化策略选择
RDB和AOF持久化如何选择?如何配置混合持久化(Redis 4.0+)? - 大Key优化
如何发现和处理Redis中的大Key(如超过1MB的String)?如何拆分? - 延迟队列实现
如何用Redis的zset实现一个延迟任务队列? - 秒杀系统设计
如何用Redis+Lua脚本实现秒杀库存的原子性扣减? - 多级缓存架构
如何设计一个包含本地缓存(Caffeine)+Redis的多级缓存系统? - 集群数据分片
Redis Cluster的槽位分配原理是什么?如何手动迁移某个Key的槽位? - 内存淘汰策略
Redis的8种内存淘汰策略(如volatile-lru、allkeys-random)如何选择? - Pipeline优化
如何用Pipeline批量执行Redis命令?与事务(MULTI)有何区别? - 慢查询分析
如何定位Redis的慢查询?如何优化keys *这类操作? - Redis事务缺陷
为什么Redis的事务不支持回滚?如何用Lua脚本弥补? - Geo数据处理
如何用Redis的GEO类型实现附近的人功能? - CPU飙升排查
Redis的CPU占用突然达到100%可能是什么原因?如何排查(如slowlog、info commandstats)?
需要这份Java面试题(2025版)文档的小伙伴,关注+留“求资料”免费领取!