总结历年各大厂面试官传授的面试经验+阿里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)即可免费领取。

猜你喜欢

转载自blog.csdn.net/JavaBUGa/article/details/112176466