跳槽时时刻刻都在发生,但是我建议大家跳槽之前,先想清楚为什么要跳槽。切不可跟风,看到同事一个个都走了,自己也盲目的开始面试起来(期间也没有准备充分),到底是因为技术原因(影响自己的发展,偏移自己规划的轨迹),还是钱给少了,不受重视。准备不充分的面试,完全是浪费时间,更是对自己的不负责(如果 title 很高,当我没说)。

今天给大家分享下 chenssy 在这次跳槽中整理的 Java 面试大纲,其中大部分都是面试过程中的面试题,可以对照这查漏补缺,当然了,这里所列的肯定不可能覆盖全部方式。
篇幅限制下面就只能给大家展示小册部分内容了。整理了一份核心面试笔记包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题
需要全套面试笔记及答案可以在文末获取
01 Java 基础
-
List 和 Set 的区别
-
HashSet 是如何保证不重复的
-
HashMap 是线程安全的吗,为什么不是线程安全的(最好画图说明多线程环境下不安全)?
-
HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的?
-
final finally finalize
-
强引用 、软引用、 弱引用、虚引用
-
Java 反射
-
Arrays.sort 实现原理和 Collection 实现原理
-
LinkedHashMap 的应用
-
cloneable 接口实现原理
-
异常分类以及处理机制
-
wait 和 sleep 的区别
02 Java 并发
-
synchronized 的实现原理以及锁优化?
-
volatile 的实现原理?
-
Java 的信号灯?
-
synchronized 在静态方法和普通方法的区别?
-
怎么实现所有线程在等待某个事件的发生才会去执行?
-
CAS?CAS 有什么缺陷,如何解决?
-
synchronized 和 lock 有什么区别?
-
Hashtable 是怎么加锁的 ?
-
HashMap 的并发问题?
-
ConcurrenHashMap 介绍?1.8 中为什么要用红黑树?
-
AQS
-
如何检测死锁?怎么预防死锁?
-
Java 内存模型?
-
如何保证多线程下 i++ 结果正确?
-
线程池的种类,区别和使用场景?
-
分析线程池的实现原理和线程的调度过程?
-
线程池如何调优,最大数目如何确认?
-
ThreadLocal 原理,用的时候需要注意什么
-
CountDownLatch 和 CyclicBarrier 的用法,以及相互之间的差别?
-
LockSupport 工具
-
Condition 接口及其实现原理
-
Fork/Join 框架的理解
-
分段锁的原理,锁力度减小的思考
-
八种阻塞队列以及各个阻塞队列的特性
03 Spring
-
BeanFactory 和 FactoryBean
-
Spring IOC 的理解,其初始化过程?
-
BeanFactory 和 ApplicationContext?
-
Spring Bean 的生命周期,如何被管理的?Spring Bean 的加载过程是怎样的?
-
如果要你实现 Spring AOP,请问怎么实现?
-
如果要你实现 Spring IOC,你会注意哪些问题?
-
Spring 是如何管理事务的,事务管理机制?
-
Spring 的不同事务传播行为有哪些,干什么用的?
-
Spring 中用到了那些设计模式?
-
Spring MVC 的工作原理?
-
Spring 循环注入的原理?
-
Spring 如何保证 Controller 并发的安全?
05 分布式相关
-
Dubbo 的底层实现原理和机制
-
描述一个服务从发布到被消费的详细过程
-
分布式系统怎么做服务治理
-
接口的幂等性的概念
-
消息中间件如何解决消息丢失问题
-
Dubbo 的服务请求失败怎么处理
-
重连机制会不会造成错误
-
对分布式事务的理解
-
如何实现负载均衡,有哪些算法可以实现?
-
Zookeeper 的用途,选举的原理是什么?
-
数据的垂直拆分水平拆分。
-
zookeeper 原理和适用场景
-
zookeeper watch 机制
-
redis/zk 节点宕机如何处理
-
分布式集群下如何做到唯一序列号
-
如何做一个分布式锁
-
用过哪些 MQ,怎么用的,和其他 mq 比较有什么优缺点,MQ 的连接是线程安全的吗
-
MQ 系统的数据如何保证不丢失
-
列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问题
-
zookeeper 的选举策略
06 数据库
-
事务四大特性(ACID)原子性、一致性、隔离性、持久性?
-
事务的并发?事务隔离级别,每个级别会引发什么问题,MySQL 默认是哪个级别?
-
MySQL 常见的三种存储引擎(InnoDB、MyISAM、MEMORY)的区别?
-
MySQL 的 MyISAM 与 InnoDB 两种存储引擎在,事务、锁级别,各自的适用场景?
-
查询语句不同元素(where、jion、limit、group by、having 等等)执行先后顺序?
-
什么是临时表,临时表什么时候删除?
-
MySQL B+Tree 索引和 Hash 索引的区别?
-
sql 查询语句确定创建哪种类型的索引?如何优化查询?
-
聚集索引和非聚集索引区别?
-
有哪些锁(乐观锁悲观锁),select 时怎么加排它锁?
-
非关系型数据库和关系型数据库区别,优势比较?
-
数据库三范式,根据某个场景设计数据表?
-
数据库的读写分离、主从复制,主从复制分析的 7 个问题?
-
使用 explain 优化 sql 和索引?
-
MySQL 慢查询怎么解决?
-
什么是 内连接、外连接、交叉连接、笛卡尔积等?
-
mysql 都有什么锁,死锁判定原理和具体场景,死锁怎么解决?
-
varchar 和 char 的使用场景?
-
mysql 高并发环境解决方案?
-
数据库崩溃时事务的恢复机制(REDO 日志和 UNDO 日志)?
07 Redis
-
Redis 用过哪些数据数据,以及 Redis 底层怎么实现
-
Redis 缓存穿透,缓存雪崩
-
如何使用 Redis 来实现分布式锁
-
Redis 的并发竞争问题如何解决
-
Redis 持久化的几种方式,优缺点是什么,怎么实现的
-
Redis 的缓存失效策略
-
Redis 集群,高可用,原理
-
Redis 缓存分片,Redis 的数据淘汰策略
08 Netty
-
BIO、NIO 和 AIO
-
Netty 的各大组件,Netty 的线程模型
-
TCP 粘包/拆包的原因及解决方法
-
了解哪几种序列化协议?包括使用场景和如何去选择
-
Netty 的零拷贝实现
-
Netty 的高性能表现在哪些方面
09 JVM
-
详细 jvm 内存模型
-
讲讲什么情况下回出现内存溢出,内存泄漏?
-
说说 Java 线程栈
-
JVM 年轻代到年老代的晋升过程的判断条件是什么呢?
-
JVM 出现 fullGC 很频繁,怎么去线上排查问题?
-
类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式?
-
类的实例化顺序
-
JVM 垃圾回收机制,何时触发 MinorGC 等操作
-
JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的
-
各种回收器,各自优缺点,重点 CMS、G1
-
各种回收算法
-
OOM 错误,stackoverflow 错误,permgen space 错误
以上这些面试题的答案大部分小编都已整理,由于篇幅有限,这里就不一一罗列了,
篇幅限制下面就只能给大家展示小册部分内容了。整理了一份核心面试笔记包括了:Java面试、Spring、JVM、MyBatis、Redis、MySQL、并发编程、微服务、Linux、Springboot、SpringCloud、MQ、Kafka 面试专题
需要全套面试笔记及答案可以点击下方名片获取

(2)Redis

(3)Java 专题面试(Java 基础,并发,分布式,微服务,Netty,Spring 等)