写点什么

总结历年各大厂面试官传授的面试经验 + 阿里 P8 级架构师整理的 Java 高频核心知识点

发布于: 2021 年 02 月 18 日

前言:

一直以来 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)即可免费领取。






用户头像

微信:tkzl6666 添加获取你想要的Java资料 2019.01.29 加入

添加VX(tkzl6666 ) 获取大厂面试真题,面试复习资料,Java进阶资料,Java实战项目。

评论 (1 条评论)

发布
用户头像
总结历年各大厂面试官传授的面试经验 + 阿里 P8 级架构师整理的 Java 高频核心知识点
2021 年 02 月 18 日 16:25
回复
没有更多了
总结历年各大厂面试官传授的面试经验+阿里P8级架构师整理的Java高频核心知识点