说明
本文分享 Java 后端真实高频面试题,有详细答案,保你稳过面试。题目包括:Java 基础、多线程、JVM、数据库、Redis、Shiro、Spring、SpringBoot、MyBatis、MQ、ELK、SpringCloud、设计模式等。
包含从简单到困难、从高频到低频的题目,适合所有 Java 求职者,包括:应届生、转行的、三年以内经验的、三到五年经验的、五到十年经验的等。
你要跳槽时是否遇到过如下问题?
-
没有题库,不知道如何开始复习
-
有题库,但题目超级多,根本看不完
-
背完题库中的面试题了,却发现面试官的问题大部分都不在题库中,导致面试老是挂,拿不到 offer
此套面试题的特点
-
这是一套真实、靠谱的题目。它的特点是:
-
很强大,面试官的问题基本都在这套题里(看过这套题的朋友都说,面试时 85%以上的题目都在这些题目里,成为了 offer 收割机)
-
真实、靠谱(这套题是我在几十场面试中被面试官问到的问题)
-
精选、高频(数量合适,很快就能看完)
-
有难度和频率的标记(着急跳槽的可以只看频率为三颗星及以上的题目)
看过我这篇文章的几个朋友和同事参加了面试后跟我说,他们面试被问到的问题大部分(85%以上)都在这个文章里。
我在面试时经常会遇到这种情况:95%的题目在本文中,我对答如流,不知道面试官是否会怀疑泄题了。这些面试也都很稳地拿到了 offer。
难度与频率
面试题采用五角星来评判题目的难度和被问到的频率,最高为五颗星。
如果是三年以上的经验,只看难度为三颗星及以上的题目即可。如果是一两年经验,看个人水平,水平好些的可以看一颗星到五颗星所有题目(我知道有这样的朋友:虽然经验少,但爱学习,一两年的经验拥有普通人四五年的技术能力)
基础(难度:★★★ 频率:★)
String
-
String, StringBuffer, StringBuilder 区别(难度:★ 频率:★★★)
-
String 对象数目(难度:★★★ 频率:★)
-
intern 方法的作用(难度:★★★ 频率:★)
-
如何修改 String 对象的数据?(难度:★★★ 频率:★★)
static
-
static 的 5 种用法(难度:★★ 频率:★)
-
为什么静态方法不能调用非静态方法和变量?(难度:★★★ 频率:★★★)
异常
-
异常类型(难度:★★ 频率:★★★★)
-
catch 里 return 了,finally 是否执行?(难度:★★ 频率:★)
IO
-
字节流与字符流区别?(难度:★★ 频率:★★)
-
BIO, NIO, AIO 区别?(难度:★★★ 频率:★)
JDK8
-
JDK8 新特性(难度:★★ 频率:★★)
-
JDK8 接口的 default 和 static(难度:★★ 频率:★)
-
JDK8 Stream API 流操作包括哪些部分?项目中怎么用的 Stream?(难度:★★ 频率:★)
语法
-
项目中对泛型的使用(难度:★★ 频率:★★)
-
接口与抽象类的区别?(难度:★★ 频率:★)
类库
-
SimpleDateFormat 线程安全吗?怎么保证线程安全?(难度:★★★ 频率:★★★)
反射
-
Java 反射:forName 和 classLoader 的区别(难度:★★★ 频率:★)
-
反射机制中可以获取 private 成员的值吗?(难度:★★★ 频率:★)
-
可以。法 1.通过 setter 和 getter 获得 法 2:通过 Field 类提供的 set()和 get()方法
-
另见《Java 开发实战经典 第 2 版》=> 15.4 Java 反射机制的深入应用
其他
-
拆箱与装箱(难度:★ 频率:★)
集合
List
-
List 与 Set 的区别(难度:★ 频率:★)
-
ArrayList 与 LinkedList 异同点?(难度:★ 频率:★★)
-
List 与数组的区别?(难度:★ 频率:★)
-
ArrayList 是否线程安全?如何线程安全地操作 ArrayList?(难度:★★★ 频率:★★★★★)
-
ArrayList 扩容机制(难度:★★★ 频率:★★★★)
-
List.subList 的坑?(难度:★★ 频率:★)
-
List 如何安全删除(难度:★★ 频率:★)
-
List 如何去重?(难度:★ 频率:★★)
-
List 如何实现排序(难度:★ 频率:★★)
-
为什么引入迭代器?(难度:★★ 频率:★)
-
List 哪种遍历性能好,为什么?(难度:★★ 频率:★)
Map
1.HashMap、TreeMap、LinkedHashMap 和区别?(难度:★★ 频率:★★★★★)
2.JDK8 的 HashMap 和 ConcurrentHashMap 的改变?(难度:★★ 频率:★★★★)
3.HashMap 数据结构、哈希冲突解决方法(难度:★★★ 频率:★★★★)
4.HashMap 扩容的原理(难度:★★★ 频率:★★★★)
5.HashMap 为什么线程不安全?如何线程安全地操作?(难度:★★★ 频率:★★★★★)
6.ConcurrentHashMap 原理?(难度:★★★ 频率:★★★★★)
7.String 的 hashCode 怎么实现的?(难度:★★ 频率:★)
8.hash:s[0] * 31^(n-1) + s[1] * 31^(n-2) + ... + s[n-1]
9.HashMap 和 HashSet 的区别及其实现原理?(难度:★★ 频率:★)
-
HashMap:将 key.hashCode()作为 hash 值存放,将 value 直接作为 value。
-
HashSet:调用 HashMap 的 put 方法;将 key.hashCode()作为 hash 值存放,将 HashSet 类的 final 变量 PRESENT 作为 value。
10.HashMap 如果使用对象最为 key,要注意什么?(难度:★★ 频率:★)
-
重写 hashCode 和 equals。
11.对象比较为什么重写 hashCode 和 equals?(难度:★★ 频率:★)
重写 equals 方法时需要重写 hashCode 方法,主要是针对 Map、Set 等集合类型的使用
-
a: Map、Set 等集合类型存放的对象必须是唯一的;
-
b: 集合类判断两个对象是否相等,是先判断 HashCode 是否相等,如果 HashCode 返回 TRUE,还要再判断 equals 返回值是否 ture,只有两者都返回 ture,才认为该两个对象是相等的。
JVM
运行时数据区
-
运行时数据区是怎样的?线程安全(即线程私有)的有哪些?(难度:★★ 频率:★★★★)
-
对象实例、类信息、常量、静态变量分别在运行时数据区的哪个位置?(难度:★★ 频率:★★)
类加载
-
Java 类加载流程?初始化流程?(难度:★★ 频率:★★★★★)
-
JVM 双亲委派模型(难度:★★★ 频率:★)
内存泄露
-
Java 内存泄露什么时候会发生?(难度:★★ 频率:★★)
-
为什么内部类持有外部类可能内存泄露?如何解决?(难度:★★ 频率:★)
-
为什么 ThreadLocal 会导致内存泄露?如何解决?(难度:★★★ 频率:★★)
垃圾回收
1.引用类型及其含义(难度:★★ 频率:★★★)
2.finalize 方法做什么用的?(难度:★ 频率:★)
-
垃圾回收时会调用此方法
3.可以作为 GC.Roots 的对象有哪些?(难度:★★★ 频率:★)
4.调用 System.gc()会立刻垃圾回收吗?(难度:★★ 频率:★)
5.Minor GC 和 Full GC 的触发时机。(难度:★★★ 频率:★★)
6.频繁 Full GC 如何排查(难度:★★★★ 频率:★)
7.JDK 默认的垃圾回收器是什么?(难度:★★ 频率:★)
8.CMS 垃圾回收器的流程?(难度:★★★ 频率:★★★★)
9.CMS 和 G1 区别(难度:★★★ 频率:★★★)
10.CMS 与其他老年代垃圾回收器的区别?(难度:★★★ 频率:★)
JVM 调优
-
JVM 通常设置哪些参数来调优?(难度:★★ 频率:★★★★)
其他
-
怎么分配堆外内存(难度:★★ 频率:★)
多线程
综合
1.项目中哪些地方用到了多线程?(难度:★★★ 频率:★★★★★)
-
处理定时的任务。 比如:定时器定时处理数据进行统计等
-
异步处理。 比如:发邮件, 记录日志, 发短信等。比如注册成功后发激活邮件
-
批量处理,缩短响应时间。比如:SpringBoot--多线程处理
2.线程的安全性问题体现在哪些方面?(难度:★★ 频率:★)
3.死锁产生的条件?(难度:★★ 频率:★)
4.i++是否线程安全?(难度:★ 频率:★)
-
不是线程安全的。要线程安全可以用 java.util.concurrent.atomic
5.JMM 内存结构(难度:★★★ 频率:★★)
synchronized
-
synchronized 用于静态方法与普通方法有区别吗?(难度:★★ 频率:★★)
-
synchronized 锁的升级是怎样的?(难度:★★★ 频率:★)
线程池
-
线程池缺点(难度:★★ 频率:★★)
-
BlockingQueue:线程池 fixed, single, scheduled, cached 对应的队列(难度:★★ 频率:★★★)
-
ThreadPoolExecutor 有哪些参数?(难度:★★ 频率:★★★★★)
-
CPU 密集与 IO 密集的场景如何设置线程池参数?(难度:★★★ 频率:★★★)
-
什么时候触发最大线程条件?(难度:★★ 频率:★★★★★)
-
线程池拒绝策略有哪些?默认是哪个?(难度:★★ 频率:★★★★)
-
线程池里的异常时如何处理的?(难度:★★ 频率:★)
JUC
-
ReentrantLock 显著缺点?(难度:★★★ 频率:★★)
-
CAS 和 AQS 了解吗?原理是什么(难度:★★★ 频率:★★)
-
synchronized 与 ReentrantLock 区别?(难度:★★ 频率:★★)
-
有哪些原子类?用过哪个?(难度:★★★ 频率:★)
-
项目里用了哪些锁?(难度:★★★ 频率:★★★)
-
单体项目里用到了 ReentrantLock、synchronized;
-
单例模式里用到了 synchronized
-
JDK8 新增的异步编程了解吗?(难度:★★★ 频率:★)
-
多线程顺序交替执行的方法(有三个线程 A,B,C,依次打印出 A,B,C)(难度:★★★ 频率:★)
方案 1:Java 多线程-使用堵塞队列实现顺序消费
方案 2:模拟阻塞队列
-
使用 Object 的 wait(), notify(),使用一个互斥锁。
MySQL
综合问题
-
MyISAM 与 InnoDB 区别(难度:★ 频率:★★★★)
-
sql 注入怎么解决?(难度:★★★ 频率:★★)
-
三大范式(难度:★★ 频率:★)
-
怎么样幂等(难度:★★★ 频率:★★)
-
一条 SQL 查询语句的执行流程(难度:★★ 频率:★★)
-
大表分页的优化方法?(难度:★★★★ 频率:★)
-
为什么不要用外键?(难度:★★★ 频率:★)
-
批量往数据库导入 1000 万条数据方法?(难度:★★ 频率:★)
存储过程
-
数据库优化方式(难度:★★★ 频率:★)
建立索引、字段冗余(减少联表查询)、使用缓存、读写分离、分库分表
-
怎么调试存储过程(难度:★★ 频率:★)
-
MySQL 的三种驱动类型 难度:★★ 频率:★)
事务
-
隔离级别是怎样的?脏读、幻读是什么意思?(难度:★★★ 频率:★★★★★)
-
隔离级别如何选用?(难度:★★ 频率:★★)
-
ACID(难度:★★ 频率:★)
-
隔离级别是如何实现的?(MVCC)(难度:★★★★ 频率:★★)
-
快照读与当前读 是怎样的?(难度:★★★★ 频率:★★)
索引
-
索引的种类(难度:★★ 频率:★★★)
-
数据库使用索引的缺点?(难度:★★ 频率:★★★)
-
创建索引的原则(难度:★★ 频率:★★★★)
-
索引什么时候会失效(难度:★★ 频率:★★★★★)
-
创建了 A, B, C 联合索引,使用 B,C 能否索引(难度:★★★ 频率:★★★★★)
-
LIKE 什么时候走索引,什么时候不走索引?(难度:★★★ 频率:★★★)
-
ORDER BY 是否走索引?(难度:★★★ 频率:★★)
-
聚集索引是什么?什么是回表?(难度:★★★★ 频率:★★★★)
-
索引原理;为什么采用 B+树?(难度:★★★★ 频率:★)
锁
-
共享锁与独占锁的区别?(难度:★★ 频率:★)
-
什么时候会死锁?(难度:★★★★ 频率:★)
分库分表
-
什么时候考虑分库分表?分库分表要考虑什么问题?(难度:★★★ 频率:★)
-
原来没分库分表,后期如何分库分表?(难度:★★★★ 频率:★★)
-
分库分表的中间件(难度:★★ 频率:★★)
Sharding-JDBC、Mycat
-
水平分表,有哪些规则?(难度:★★★ 频率:★★★★★)
-
如何维护全局的 id(难度:★★★ 频率:★★★★★)
语句
语句类笔试题(难度:★★★ 频率:★)
OR 与 IN 的效率?(难度:★★★ 频率:★)
内联结,全(外)联结,左联结,右联结,的含义?(难度:★★ 频率:★)
Redis
基本问题
-
Redis 数据类型及其使用场景(难度:★★★ 频率:★★★★★)
-
Redis 的数据类型对应的底层结构是怎样的?(难度:★★★★ 频率:★★★)
-
Redis 为什么很快?(难度:★★ 频率:★★★★★)
-
Redis 是单线程为什么速度依然快?(难度:★★ 频率:★★)
-
Redis 持久化 AOF,RDB 区别(难度:★★ 频率:★★★★)
-
持久化:长久下来 AOF 文件会很大怎么办?(难度:★★★ 频率:★★)
-
Redis 有哪些原子命令?(难度:★★★ 频率:★)
Redis 所有单个命令都是原子性的。
-
穿透、无底洞、雪崩、击穿 解决方案?(难度:★★★ 频率:★★★★★)
-
Redis 的发布订阅机制及其使用场景(难度:★★★★ 频率:★★)
-
内存回收机制是怎样的?(或者说:淘汰策略)(难度:★★★ 频率:★★★★)
-
给一个 key 怎么知道是用的哪种数据类型?(难度:★ 频率:★)
用 type 命令。例如:type key1
-
为什么使用 Redis,不用 Memcache 和 MongoDB?(难度:★★ 频率:★★)
-
Redis 与数据库如何同步?各个方式的缺点是什么?(难度:★★★ 频率:★★★)
-
Redis 很慢,如何排查及解决?(难度:★★★★ 频率:★★)
-
多线程操作同一个 Key 如何保证一致性?(微服务部署多个实例时如何保证一致性?)(难度:★★★★ 频率:★)
-
秒杀的时候怎么使用 Redis?(难度:★★★★ 频率:★★★)
-
布隆过滤器原理?什么时候会误判?(难度:★★★★ 频率:★★★)
-
用 Redis 如何实现延迟队列?(难度:★★★★ 频率:★)
分布式锁
-
Redis 做分布式锁如何处理超时时间?比如:超时时间是 5 秒,但要执行 20 秒,相当于没锁住;超时时间是 20 秒,但只需执行 5 秒(浪费)(难度:★★★★ 频率:★★★)
设置中等长度的时间,线程执行完删除这个值;另起线程,定期去刷新这个值。Redisson 的分布式锁就是这个方案
-
Redis 实现分布式锁,集群环境如何处理主节点宕机这种情况?(难度:★★★★★ 频率:★)
使用 RedLock 红锁算法:若过半的 Redis 节点能够 setnx 成功则表示获取锁成功,类似于 zk 实现分布式锁方式
集群
-
多节点有哪些部署方式?(难度:★★ 频率:★)
主从、哨兵、集群(Cluster)
-
集群不支持事务,如何解决?(难度:★★★★ 频率:★)
-
主从集群中主节点死了以后,是否还能使用?如何解决?(难度:★★★ 频率:★)
可以使用哨兵部署,自动故障转移。
-
读写分离时读写分别在哪个节点(难度:★★ 频率:★)
在主节点上写,在从节点上读。
集群(Cluster)
-
集群(Cluster)如何进行节点通信?(难度:★★★★ 频率:★★)
-
集群(Cluster)如何进行扩展(伸缩)?(难度:★★★ 频率:★★)
-
集群(Cluster)如何进行故障转移?(难度:★★★★ 频率:★★)
设计模式
-
项目里用到了哪些设计模式,怎么用的?(难度:★★★ 频率:★★★★★)
-
设计模式的原则(难度:★★ 频率:★)、
-
设计模式的类别(难度:★★ 频率:★)
-
单例模式的写法?(难度:★★ 频率:★★★★)
-
手写双重检验单例(为什么用 volatile,为什么两次 if 判断)(难度:★★★ 频率:★★★)
-
静态代理与动态代理区别?(难度:★★★ 频率:★★★★★)
框架
Spring
IOC
-
Spring 循环依赖解决方法及原理(难度:★★★★ 频率:★★★★)
-
Spring 的循环依赖用的是三级缓存,为什么不是两级?(难度:★★★★ 频率:★★)
-
FactoryBean 和 BeanFactory 区别(难度:★★★★ 频率:★★)
-
BeanFactory 和 ApplicationContext 区别?(难度:★★★★ 频率:★)
-
bean 的生命周期是怎样的(难度:★★★ 频率:★)
-
Spring 几种 scope 区别(难度:★★★ 频率:★)
-
Spring 容器的生命周期是怎样的?(难度:★★★ 频率:★)
-
SpringAOP 解决了什么问题?(难度:★★★ 频率:★★)
-
SpringAOP 实际开发过什么功能?(难度:★★★ 频率:★★★)
-
AOP 原理?(难度:★★★★ 频率:★★★★★)
AOP
-
AOP 有哪几种通知,如果方法执行报异常,哪个通知不会执行?(难度:★★★★ 频率:★)
前置,后置,环绕,返回,异常。若报异常,返回不会执行。
事务
-
Spring 默认数据里隔离级别是什么?项目里用的哪个?(难度:★★★ 频率:★★)
默认采用数据库的隔离级别。项目里就是用的默认的
-
Spring 事务失效场景?(难度:★★★★ 频率:★★★★)
-
Spring 事务传播机制?(难度:★★★★ 频率:★★)
其他
-
SpringBoot 如何热部署?yml 配置文件修改后是否也能及时更新?(难度:★★★ 频率:★)
-
SpringBoot 自动配置原理?(难度:★★★★★ 频率:★)
SpringMVC
-
SpringMVC 流程(难度:★★★★ 频率:★★★)
-
servlet 的过滤器、拦截器、AOP 的执行顺序 (难度:★★★ 频率:★★)
SpringBoot
-
SpringBoot 的启动流程?(难度:★★★★ 频率:★★★★)
-
SpringBoot 的动态代理默认用的哪个(cglib 还是 JDK)?(难度:★★★★ 频率:★★★★)
SpringBoot 1.5.x:默认使用 JDK 代理,SpringBoot 2.x:默认使用 CGLIB 代理。
-
怎么自己写 SpringBootStarter(难度:★★★★ 频率:★)
MyBatis
-
MyBatis 的 #与 $有什么区别?(难度:★★ 频率:★★★★)
-
MyBatis 的原理?(Mapper 是个接口,它的实现类在哪?)(难度:★★★★ 频率:★★)
-
为什么 MyBatis 与 Spring 整合二级缓存会失效 ?(难度:★★★★ 频率:★)
中间件
MQ
综合
-
RabbitMQ,RocketMQ 和 Kafka 区别(难度:★★ 频率:★★★★★)
RabbitMQ
-
RabbitMQ 有哪些交换器?RabbitMQ 的交换器与队列的关系?(难度:★★ 频率:★★★)
-
RabbitMQ 的消息异常(丢失、重复、顺序、堆积)如何处理?(难度:★★★ 频率:★★★★★)
-
RabbitMQ 消息是否会过期?(难度:★★★ 频率:★★)
-
RabbitMQ 的消息什么时候会放到死信队列?(难度:★★★ 频率:★)
-
RabbitMQ 的延迟队列是怎样的?(难度:★★★ 频率:★★)
-
RabbitMQ 的集群有哪几种部署方式?(难度:★★ 频率:★)
多机多节点,单机多节点
Kafka
-
为什么 Kafka 性能很高(难度:★★★ 频率:★★★)
-
Kafka 的消息异常(丢失、重复)如何处理?(难度:★★★ 频率:★★★★)
-
Kafka 不支持延迟队列,如果用到延迟队列,该如何实现?(难度:★★★★★ 频率:★★★)
Shiro
-
Shiro 怎么根据 url 对应权限,流程是什么?(难度:★★★ 频率:★★★)
-
session 存放在哪里?(难度:★★ 频率:★)
分布式
综合
分布式
-
CAP 理论是什么?Zookeeper 和 Eureka 分别放弃了什么?(难度:★★★ 频率:★★★)
-
分布式锁实现方式(难度:★★★ 频率:★★★★★)
-
2PC、3PC、TCC 的区别及使用场景?(难度:★★★★ 频率:★★)
-
分布式 session 共享解决方案(难度:★★★ 频率:★★)
-
为什么微服务一定要有网关?(难度:★★★ 频率:★)
配置中心
-
如何把微服务的公共配置给拿出来?(难度:★★ 频率:★)
-
用 spring.profiles.include,将公共的配置包含进去。
-
使用 Nacos,Nacos 支持公共配置
Nacos
-
Nacos 如何续期?(难度:★★★ 频率:★★)
-
Nacos 支持 AP 还是 CP?(难度:★★★ 频率:★★)
两者都支持,选一种即可。(默认是 AP)
Zookeeper
Zookeeper 注册中心挂了,服务还能否调用?(难度:★★★ 频率:★★)
-
可以,因为客户端还有缓存
ZK 分布式锁,leader 节点宕机了,会发生什么?(难度:★★★★ 频率:★)
-
进行选举(过半选举)