总结历年各大厂面试官传授的面试经验 + 阿里 P8 级架构师整理的 Java 高频核心知识点
下面是我总结的工作或者面试必备的一些知识点文档,供大家参考。可以检测一下自己的知识是不是能跟上时代的要求。完整文档覆盖十四个大项,七十八个小项,希望能帮助到正在路上的你!

[](
)一.Java 基础
1.11 Java 反射


Java?反射的概念和应用场景
反射机制中可以获取?private?成员的值吗(没有?set?和?get?函数)可以
反射的所有包,怎实现反射
反射的定义
Java.long.reflect?里常用方法

[](
)二.集合类 Set?
2.12 hash 算法

java map 底层实现,最好看源码,还有各种集合类的区别
4. TreeMap?和?TreeSet?区别和实现原理
5.?集合和有序集合有什么区别
6. Set?是无序的,那怎么保证它有序?有什么办法吗?提到了?TreeSet,那说一下
TreeSet?为什么能够保证有序?
7. java?中?hashMap?结构,处理冲突方法,还有啥方法,各个方法优缺点
.Collections.sort()?的原理
集合框架的理解 对?Java?的集合框架有什么样的了解,?用过哪些集合类,?各自的效率以及
适用场景
cas?的实现原理,以及?aba?问题
List/Set/Queue 接口及其实现类
HashSet/TreeSet/HashMap/TreeMap/hashTable 这些类的底层实现。
常问: hashSet 和 HashMap 有什么区别 。各自的底层实现是基于什么的。
这里紧接着的问题通常是:我们来聊聊多线程(微笑脸),或者我们来聊聊红
黑树。2.13 迭代器 Iterator Enumerati

[](
)三.java 多线程
4.2.线程状态

?1、新建状态(New):新创建了一个线程对象。
?2、就绪状态(Runnable):线程对象创建后,其他线程调用了该对象的 start()方法。该状态的线程位于可运行线程池中,变得可运行,等待获取 CPU 的使用权。
3、运行状态(Running):就绪状态的线程获取了 CPU,执行程序代码。
4、阻塞状态(Blocked):阻塞状态是线程因为某种原因放弃 CPU 使用权,暂时停止运行。直到线程进入就绪状态,才有机会转到运行状态。阻塞的情况分三种:
(一)、等待阻塞:运行的线程执行 wait()方法,JVM 会把该线程放入等待池中。(wait 会释放持有的锁)
(二)、同步阻塞:运行的线程在获取对象的同步锁时,若该同步锁被别的线程占用,则 JVM 会把该线程放入锁池中。
(三)、其他阻塞:运行的线程执行 sleep()或?join()方法,或者发出了?I/O?请求时,JVM?会把该线程置为阻塞状态。当?sleep()状态超时、join()等待线程终止或者超时、或者?I/O?处理完毕时,线程重新转入就绪状态。(注意,sleep 是不会释放持有的锁)
5、死亡状态(Dead):线程执行完了或者因异常退出了?run()方法,该线程结束生命周期。???
[](
)

?
四.Java 进阶 ssh/ssm 框架
2.4 Redis
Redis?数据结构?Redis?持久化机制
Redis?的一致性哈希算法
redis 了解多少?redis 五种数据类型,当散列类型的?value?值非常大的时候怎么进行压缩,
用?redis?怎么实现摇一摇与附近的人功能,redis?主从复制过程,
Redis?如何解决?key?冲突
redis?的五种数据结构
redis?是怎么存储数据的
redis?使用场景

[](
)五.Java 内存模型 和 垃圾回收
3.9 面试问题
3.9.1 一般 Java 堆是如何实现的?
我:在 HotSpot 虚拟机实现中,Java 堆分成了新生代和老年代,我当时看的是 1.7 的实现,
所有还有永久代,新生代中又分为了 eden 区和 survivor 区,
survivor 区又分成了 S0 和 S1,
或则是 from 和 to,(这个时候,我要求纸和笔,因为我觉得这个话题可以聊蛮长时间,又
是我比较熟悉的...一边画图,一边描述),其中 eden,from 和 to 的内存大小默认是 8:1:1
(各种细节都要说出来...),此时,我已经在纸上画出了新生代和老年代代表的区域
[](
)

六.设计模式
4.1.13?组合模式
Composite?组合模式:
又叫做部分-整体模式,使得客户端看来单个对象和对象的组合是同等的。换句话说,某个
评论