总结
以上是字节二面的一些问题,面完之后其实挺后悔的,没有提前把各个知识点都复习到位。现在重新好好复习手上的面试大全资料(含JAVA、MySQL、算法、Redis、JVM、架构、中间件、RabbitMQ、设计模式、Spring等),现在起闭关修炼半个月,争取早日上岸!!!
下面给大家分享下我的面试大全资料
- 第一份是我的后端JAVA面试大全
后端JAVA面试大全
- 第二份是MySQL+Redis学习笔记+算法+JVM+JAVA核心知识整理
MySQL+Redis学习笔记算法+JVM+JAVA核心知识整理
- 第三份是Spring全家桶资料
MySQL+Redis学习笔记算法+JVM+JAVA核心知识整理
-
内存模型:程序计数器、方法区、堆、栈、本地方法栈的作用,保存哪些数据。
-
类加载:双亲委派的加载机制,以及常用类加载器分别加载哪种类型的类。
-
GC:分代回收的思想和依据,以及不同垃圾回收算法实现的思路、适合的场景。
-
性能调优:常用的 JVM 优化参数的作用,参数调优的依据,常用的 JVM 分析工具能分析哪类问题,以及使用方法。
-
执行模式:解释、编译、混合模式的优缺点,Java7 提供的分层编译技术。需要知道 JIT 即时编译技术和 OSR(栈上替换),知道 C1、C2 编译器针对的场景,其中 C2 针对 Server 模式,优化更激进。在新技术方面可以了解 Java10 提供的由 Java 实现的 Graal 编译器。
-
编译优化:前端编译器 javac 的编译过程、AST 抽象语法树、编译期优化和运行期优化。编译优化的常用技术包括公共子表达式的消除、方法内联、逃逸分析、栈上分配、同步消除等。明白了这些才能写出对编译器友好的代码。
下面咱们通过各个方面来理解 JVM 的这些知识。
2、JVM 工作流程
==========
我相信有些人跟我一样对内存的堆内存(heap)和栈内存(Stack)是怎么划分的不是很清楚,看完这块保你明白的彻彻底底。
Java 的内存区域划分实际上远比这复杂:Java 虚拟机在执行 Java 程序的过程中,会把它所管理的内存划分为不同的数据区域。下面这张图描述了一个 Scc.java 文件被 JVM 加载到内存中的过程:
-
Scc.java 文件首先需要经过编译器编译,生成 Scc.class 字节码文件。
-
Java 程序中访问Scc这个类时,需要通过 ClassLoader(类加载器)将Scc.class 加载到 JVM 的内存中。
-
JVM 中的内存可以划分为若干个不同的数据区域,主要分为:程序计数器、虚拟机栈、本地方法栈、堆、方法区。
3、相关推荐
======
最后
我还为大家准备了一套体系化的架构师学习资料包以及BAT面试资料,供大家参考及学习
已经将知识体系整理好(源码,笔记,PPT,学习视频)
a03fab5e56a57acb)收录**