总结历年各大厂面试官传授的面试经验 + 阿里 P8 级架构师整理的 Java 高频核心知识点
前言:
一直以来 Java 程序员最关注的问题:Java 的学习路径?Java 要学到什么程度才可以就业?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 组合模式:
又叫做部分-整体模式,使得客户端看来单个对象和对象的组合是同等的。换句话说,某个
类型的方法同时也接受自身类型作为参数。
avax.swing.JComponent#add(Component)
java.util.Map#putAll(Map)
java.util.List#addAll(Collection)
java.util.Set#addAll(Collection)
七.数据结构与算法
八.数据库
8.7 数据库范式
1NF:符合 1NF 的关系中的每个属性都不可再分
2NF∶属性完全依赖于主键[消除部分子函数依赖]
3NF:属性不依赖于其它非主属性[消除传递依赖]
BCNF:在 1NF 基础上,任何非主属性不能对主键子集依赖[在 3NF 基础上消除对主码子集的依赖
4NF:要求把同一表内的多对多关系删除。
5NF:从最终结构重新建立原始结构。
九.操作系统
10.2.2 死锁避免-安全序列
安全序列
安全序列是指对当前申请资源的进程排出一个序列,保证按照这个序列分配资源完成进程,不会发生 “ 酱油和醋 ” 的尴尬
问题。
我们假设有进程 P1,P2,.....Pn
则安全序列要求满足: Pi(1<=i<=n) 需要资源 <= 剩余资源 + 分配给 Pj(1 <= j < i) 资源
为什么等号右边还有已经被分配出去的资源?想想银行家那个问题,分配出去的资源就好比第二个开发商,人家能还回
来钱,咱得把这个考虑在内。
十.Linux 命令
10.9 linux 锁
1.互斥锁
互斥锁只能有对一个线程使用,就是用来互斥的。
以下是互斥锁的基本操作
3. 自旋锁
自旋锁上锁后让等待线程进行忙等待而不是睡眠阻塞,而信号量是让等待线程睡眠阻塞。
自旋锁的忙等待浪费了处理器的时间,但时间通常很短,在 1 毫秒以下。
十一.项目
由于文章篇幅原因,只能展示部分文档。需要整份文档资料以及以下我整理的历年大厂面试题的一键三连+评论,然后添加我的 VX(tkzl6666)即可免费领取。
评论 (1 条评论)