作为一名 Java 从业者,虽然近几年,无论是使用规模、开发者人数,还是技术生态成熟度、相关工具的丰富程度,Java 都在后端开发语言中有着不可撼动的地位,也是开发各类业务系统的首选语言。
而且薪资也非常可观 👇
(
图源:职友集
2020年北京
Java 程序员工资情况
)
但很多同学却总有种“做不动”的感觉。项目还好说,用 Java 写系统代码都没有问题,可一旦有人问到 Java 程序运行起来以后内部发生了什么,怎么让它运行的更好?大多数同学就可能答不上来了。
而现在面试 Java 岗位,无论什么规模的公司,面试官必问到 JVM 相关的问题,
什么线程、内存模型、JVM 运行时内存、垃圾回收与算法、GC 垃圾收集器、JAVA IO/NIO 、JVM 类加载机制
等等知识点。
在面试中,这些问题如果答不好,可能直接影响你的薪资。
这里和大家分享一张 JVM 和性能优化大图,包含了 Java 工程师一定要花时间学会的
Java 内存区域、垃圾回收器和内存分配策略、JVM 的执行子系统、编写高效优雅 Java 程序、性能优化
等等知识点。(感兴趣的同学可以扫码领取高清完整版图谱)
(扫码领取完整版图谱)
接下来就带大家详细了解一下,
2020 年一线大厂技术面试 JVM 知识的必考问题
,看看你能答出几道?
......
不同虚拟机的运行时数据区可能略微有所不同,但都会遵从 Java 虚拟机规范, Java 虚拟机规范规定的区域分为以下 5 个部分:
程序计数器
当前线程所执行的字节码的行号指示器,字节码解析器的工作是通过改变这个计数器的值,来选取下一条需要执行的字节码指令,分支、循环、跳转、异常处理、线程恢复等基础功能;
Java 虚拟机栈
用于存储局部变量表、操作数栈、动态链接、方法出口等信息;
本地方法栈
与虚拟机栈的作用是一样的,只不过虚拟机栈是服务 Java 方法的,而本地方法栈是为虚拟机调用 Native 方法服务的;
Java 堆
Java 虚拟机中内存最大的一块,是被所有线程共享的,几乎所有的对象实例都在这里分配内存;
方法区
用于存储已被虚拟机加载的类信息、常量、静态变量、即时编译后的代码等数据。
并行收集器:
串行收集器使用一个单独的线程进行收集,GC 时服务有停顿时间。
串行收集器:
次要回收中使用多线程来执行。
CMS 收集器
是基于“标记—清除”算法实现的,经过多次标记才会被清除。
G1
从整体来看是基于“标记—整理”算法实现的收集器,从局部(两个 Region 之间)上来看是基于“复制”算法实现的。