大厂面试题-JVM为什么使用元空间替换了永久代?

目录

面试解析

问题答案


面试解

我们都知道Java8以及以后的版本中,JVM运行时数据区的结构都在慢慢调整和优化。但实际上这些变化,对于业务开发的小伙伴来说,没有任何影响。

因此我可以说,99%的人都回答不出这个问题。

但是互联网大厂的面试就是筛选那1%的优秀人才,因此通过这道题:

1、既可以考察求职者对JVM原理的理解程度

2、又能够考察求职者基本功的扎实程度

3、还能实现高级人才的筛选

在Java7里面,JVM运行时数据区是这样的(如图)。

在Hotspot虚拟机中,方法区的实现是在永久代里面,它里面主要存储运行时常量池、Klass类元信息等。

永久代属于JVM运行时内存中的一块存储空间,我们可以通过-XX:PermSize来设置永久代的大小。

当内存不够的时候,会触发垃圾回收。

在JDK1.8里面,JVM运行时数据区是这样的(如图)

在Hotspot虚拟机中,取消了永久代,由元空间来实现方法区的数据存储。

元空间不属于JVM内存,而是直接使用本地内存,因此不需要考虑GC问题。

默认情况下元空间是可以无限制的使用本地内存的,但是我们也可以使用JVM参数来限制内存使用大小。

为什么要使用元空间来替换永久代,背后必然有它的道理,但是如果求职者能够回答出来。

必然对于JVM底层原理是有一定了解的。

题答案

有三个方面的原因:

1、在1.7版本里面,永久代内存是有上限的,虽然我们可以通过参数来设置,但是JVM加载的class总数、大小是很难确定的。所以很容易出现OOM问题。

但是元空间是存储在本地内存里面,内存上限比较大,可以很好的避免这个问题。

2、永久代的对象是通过FullGC进行垃圾收集,也就是和老年代同时实现垃圾收集。替换成元空间以后,简化了Full GC。可以在不进行暂停的情况下并发地释放类数据,同时也提升了GC的性能。

3、Oracle要合并Hotspot和JRockit的代码,而JRockit没有永久代。

相关推荐
假如让我当三天老蒯4 小时前
模块化:ES Module 与 CommonJS 的区别
前端·面试
沉默王二4 小时前
面试官:RAG 不用向量数据库,用 MySQL 硬扛?我:100 万向量不是很轻松?
mysql·面试·ai编程
Darling噜啦啦1 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
swipe1 天前
正则表达式入门到进阶:从表单校验到手写模板引擎
前端·javascript·面试
神奇小汤圆1 天前
RAG大厂面试题汇总:向量检索、混合检索、Rerank、幻觉处理高频问题
面试
假如让我当三天老蒯1 天前
回归基本功:Map/Set 与 WeakMap/WeakSet 的区别
前端·面试
假如让我当三天老蒯1 天前
回归基本功!前端的解构赋值、扩展运算符、剩余参数
前端·面试
Lee川1 天前
Memory 模块深度解析(面试向)
人工智能·面试
源分享2 天前
Java线程同步的多种实现方法(非常详细)
java·开发语言·jvm