跳槽时时刻刻都在发生,但是我建议大家跳槽之前,先想清楚为什么要跳槽。切不可跟风,看到同事一个个都走了,自己也盲目的面试起来(期间也没有准备充分),到底是因为技术原因(影响自己的发展,偏移自己规划的轨迹),还是钱给少了,不受重视。
准备不充分的面试,完全是浪费时间,更是对自己的不负责(如果title很高,当我没说)。
今天给大家分享下chenssy在这次跳槽中整理的Java面试大纲,其中大部分都是面试过程中的面试题,可以对照这查漏补缺,当然了,这里所列的肯定不可能覆盖全部方式。
项目介绍
大部分情况,这是一场面试的开门题,面试官问这个问题,主要是考察你的概述能力和全局视野。有的人经常抱怨自己每天在堆业务,但没有成长。事实上,很多情况下确实在堆业务,但并不是没有成长的。并非做中间件或者技术架构才是成长,例如我们的需求分析能力,沟通协作能力,产品思维能力,抽象建模能力等都是一个非常重要的硬实力。
好的,现在进入正文。
1、明确项目是做什么的
2、明确项目的价值。(为什么做这个项目,它解决了用户什么痛点,它带来什么价值?)
3、明确项目的功能。(这个项目涉及哪些功能?)
4、明确项目的技术。(这个项目用到哪些技术?)
5、明确个人在项目中的位置和作用。(你在这个项目的承担角色?)
6、明确项目的整体架构。
7、明确项目的优缺点,如果重新设计你会如何设计。
8、明确项目的亮点。(这个项目有什么亮点?)
9、明确技术成长。(你通过这个项目有哪些技术成长?)
Java基础
1、List 和 Set 的区别
https://www.cnblogs.com/jing99/p/6947549.html
2、HashSet 是如何保证不重复的
3、HashMap 是线程安全的吗,为什么不是线程安全的(最好画图说明多线程环境下不安全)?
https://www.cnblogs.com/xiaoxi/p/7233201.html
4、HashMap 的扩容过程
https://blog.csdn.net/aichuanwendang/article/details/53317351
数组的大小乘以2,创建一个新的Entry数组,再重新计算hash值,再插入到新数组。
5、HashMap 1.7 与 1.8 的 区别,说明 1.8 做了哪些优化,如何优化的?
https://blog.csdn.net/kenzhang28/article/details/80212936
https://blog.csdn.net/kenzhang28/article/details/80303292
6、final finally finalize
https://blog.csdn.net/cyl101816/article/details/67640843
7、强引用 、软引用、 弱引用、虚引用
8、Java反射
9、Arrays.sort 实现原理和 Collection 实现原理
10、LinkedHashMap的应用
11、cloneable接口实现原理
12、异常分类以及处理机制
- Java 中所有异常都是
Throwable
的子类,他的直接子类有两个,一个是Error
, 一个是Exception
。Error
一般表示 JVM 出现了严重问题,比如说栈溢出或 OOM,Exception
中异常分为两类,一类是RuntimeException
表示运行期间出现的错误,比较常见的是空指针异常和数组下标越界,出现这种异常一般是程序出现了逻辑错误,也就是代码有 Bug。另一类是编译时异常(除了RuntimeException
以外的异常),常见的一般有IOException
等, 出现这种错误程序编译会不通过。 - 还有一种分类方式是
checked exception
和uncheck exception
。unchecked exception
包括Error
和RuntimeExcetion
,checked exception
指之前所说的编译时异常。
http://www.runoob.com/java/java-exceptions.html
检查性异常和非检查性异常
https://www.cnblogs.com/xh_chiang/p/6850847.html
ClassNotFoundException | NoClassDefFoundError |
从java.lang.Exception继承,是一个Exception类型 | 从java.lang.Error继承,是一个Error类型 |
当动态加载Class的时候找不到类会抛出该异常 | 当编译成功以后执行过程中Class找不到导致抛出该错误 |
一般在执行Class.forName()、ClassLoader.loadClass()或ClassLoader.findSystemClass()的时候抛出 | 由JVM的运行时系统抛出 |
http://www.cnblogs.com/duke2016/p/9153241.html
13、wait和sleep的区别
https://www.jianshu.com/p/25e243850bd2?appinstall=0
14、数组在内存中如何分配
15、快排
https://www.cnblogs.com/JiaJoa/p/7810054.html
16、线程安全的集合
vector、hashtable、concurrentHashMap、StringBuffer(字符串)
IO与NIO
19 compareable 与 comparetor区别
https://www.cnblogs.com/xujian2014/p/5215082.html
Comparable是排序接口,若一个类实现了Comparable接口,就意味着“该类支持排序”。而Comparator是比较器,我们若需要控制某个类的次序,可以建立一个“该类的比较器”来进行排序。
Comparable相当于“内部比较器”,而Comparator相当于“外部比较器”。
两种方法各有优劣, 用Comparable 简单, 只要实现Comparable 接口的对象直接就成为一个可以比较的对象,但是需要修改源代码。 用Comparator 的好处是不需要修改源代码, 而是另外实现一个比较器, 当某个自定义的对象需要作比较的时候,把比较器和对象一起传递过去就可以比大小了, 并且在Comparator 里面用户可以自己实现复杂的可以通用的逻辑,使其可以匹配一些比较简单的对象,那样就可以节省很多重复劳动了。
Java 并发
17、Runnable和Thread区别
实现Runnable接口比继承Thread类所具有的优势:
1):适合多个相同的程序代码的线程去处理同一个资源
2):可以避免java中的单继承的限制
3):增加程序的健壮性,代码可以被多个线程共享,代码和数据独立
https://www.cnblogs.com/yangdy/p/5274455.html
1、synchronized 的实现原理以及锁优化?
2、volatile 的实现原理?
3、Java 的信号灯?
https://blog.csdn.net/zzp_403184692/article/details/8017173
4、synchronized 在静态方法和普通方法的区别?
5、怎么实现所有线程在等待某个事件的发生才会去执行?
6、CAS?CAS 有什么缺陷,如何解决?
https://www.cnblogs.com/qjjazry/p/6581568.html
7、synchronized 和 lock 有什么区别?
https://www.cnblogs.com/zouzz/p/6593748.html
表格总结区别: https://blog.csdn.net/u012403290/article/details/64910926?locationNum=11&fps=1
讲述详细: https://www.cnblogs.com/baizhanshi/p/6419268.html
8、Hashtable 是怎么加锁的 ?
9、HashMap 的并发问题?
10、ConcurrenHashMap 介绍?1.8 中为什么要用红黑树?
11、AQS
12、如何检测死锁?怎么预防死锁?
13、Java 内存模型?
https://blog.csdn.net/weixin_42463676/article/details/80936970
14、如何保证多线程下 i++ 结果正确?
15、线程池的种类,区别和使用场景?
https://www.jianshu.com/p/87bff5cc8d8c
16、分析线程池的实现原理和线程的调度过程?
17、线程池如何调优,最大数目如何确认?
18、ThreadLocal原理,用的时候需要注意什么?
https://blog.csdn.net/sonny543/article/details/51336457
https://www.cnblogs.com/micrari/p/6790229.html
19、CountDownLatch 和 CyclicBarrier 的用法,以及相互之间的差别?
例子举得好:http://www.importnew.com/21889.html
https://blog.csdn.net/tolcf/article/details/50925145
20、LockSupport工具
21、Condition接口及其实现原理
22、Fork/Join框架的理解
23、分段锁的原理,锁力度减小的思考
24、八种阻塞队列以及各个阻塞队列的特性
25、检查性异常和非检查性异常
https://www.cnblogs.com/tjudzj/p/7053980.html
Spring
1、BeanFactory 和 FactoryBean?
https://blog.csdn.net/qiesheng/article/details/72875315
2、Spring IOC 的理解,其初始化过程?
https://blog.csdn.net/GoGleTech/article/details/78977391
初始化过程:https://blog.csdn.net/wenbo20182/article/details/50206457
3、BeanFactory 和 ApplicationContext?
(1)BeanFactory接口的实现类是一个简单容器系列,该系列的容器只实现了容器最基本的功能;
(2)ApplicationContext接口的实现类是一个高级容器系列,该系列的容器在简单容器的基础上增加了很多面向框架的特性,对应用环境做了很多适配,同时添加了很多面向应用的功能,例如:国际化支持和框架事件体系结构等。
5、Spring Bean 的加载过程是怎样的?
https://www.cnblogs.com/leskang/p/6411011.html
6、Spring AOP底层实现?
http://www.importnew.com/24305.html
https://blog.csdn.net/dreamrealised/article/details/12885739
8、Spring 是如何管理事务的,事务管理机制?
https://blog.csdn.net/jie_liang/article/details/77600742
9、Spring 的不同事务传播行为有哪些,干什么用的?
https://www.cnblogs.com/softidea/p/5962612.html
https://blog.csdn.net/weixin_39625809/article/details/80707695
10、Spring 中用到了那些设计模式?
11、Spring MVC 的工作原理?
https://www.cnblogs.com/xiaoxi/p/6164383.html
12、Spring 循环注入的原理?
13、Spring AOP的理解,各个术语,他们是怎么相互工作的?
14、Spring 如何保证 Controller 并发的安全?
15、springboot初始化资源方式
https://blog.csdn.net/qq_28804275/article/details/80891941
Netty
1、BIO、NIO和AIO
2、Netty 的各大组件
3、Netty的线程模型
4、TCP 粘包/拆包的原因及解决方法
5、了解哪几种序列化协议?包括使用场景和如何去选择
6、Netty的零拷贝实现
7、Netty的高性能表现在哪些方面
分布式相关
1、Dubbo的底层实现原理和机制
2、描述一个服务从发布到被消费的详细过程
3、分布式系统怎么做服务治理
4、接口的幂等性的概念
https://blog.csdn.net/jks456/article/details/71453053
5、消息中间件如何解决消息丢失问题
6、Dubbo的服务请求失败怎么处理
7、重连机制会不会造成错误
8、对分布式事务的理解
http://www.cnblogs.com/LBSer/p/4715395.html
https://www.cnblogs.com/lzyGod/p/5558474.html
9、如何实现负载均衡,有哪些算法可以实现?
10、Zookeeper的用途,选举的原理是什么?
11、数据的垂直拆分水平拆分。
12、zookeeper原理和适用场景
13、zookeeper watch机制
14、redis/zk节点宕机如何处理
15、分布式集群下如何做到唯一序列号
16、如何做一个分布式锁
https://blog.csdn.net/u010442302/article/details/78972311
17、用过哪些MQ,怎么用的,和其他mq比较有什么优缺点,MQ的连接是线程安全的吗
18、MQ系统的数据如何保证不丢失
19、列举出你能想到的数据库分库分表策略;分库分表后,如何解决全表查询的问题
20、zookeeper的选举策略
21、全局ID
22、秒杀
https://www.cnblogs.com/phpper/p/7085663.html
数据库
1、mysql分页有什么优化
2、悲观锁、乐观锁
https://www.cnblogs.com/qjjazry/p/6581568.html
3、组合索引,最左原则
4、mysql 的表锁、行锁
好文: https://www.cnblogs.com/chenqionghe/p/4845693.html
5、mysql 性能优化
6、mysql的索引分类:B+,hash;什么情况用什么索引
7、事务的特性和隔离级别
https://www.cnblogs.com/fjdingsd/p/5273008.html
8、mysql死锁
http://www.cnblogs.com/LBSer/p/5183300.html
缓存
https://blog.csdn.net/hjm4702192/article/details/80518856
1、Redis用过哪些数据数据,以及Redis底层怎么实现
2、Redis缓存穿透,缓存雪崩
3、如何使用Redis来实现分布式锁
https://blog.csdn.net/u010442302/article/details/78972311
4、Redis的并发竞争问题如何解决
5、Redis持久化的几种方式,优缺点是什么,怎么实现的
6、Redis的缓存失效策略
7、Redis集群,高可用,原理
8、Redis缓存分片
9、Redis的数据淘汰策略
JVM
1、 详细jvm内存模型
https://www.cnblogs.com/xing901022/p/7725961.html
2、讲讲什么情况下回出现内存溢出,内存泄漏?
3、说说Java线程栈
4、JVM 年轻代到年老代的晋升过程的判断条件是什么呢?
5、JVM 出现 fullGC 很频繁,怎么去线上排查问题?
6、类加载为什么要使用双亲委派模式,有没有什么场景是打破了这个模式?
7、类的实例化顺序
8、JVM垃圾回收机制,何时触发MinorGC等操作
9、JVM 中一次完整的 GC 流程(从 ygc 到 fgc)是怎样的
10、各种回收器,各自优缺点,重点CMS、G1
11、各种回收算法
https://blog.csdn.net/wen7280/article/details/54428387
12、OOM错误,stackoverflow错误,permgen space错误
13、jvm类加载顺序
http://www.importnew.com/25295.html
补充:
JWT
http://www.ruanyifeng.com/blog/2018/07/json_web_token-tutorial.html