[已关闭]JDK8 以后还有永久代么?如果有的话是在堆区么?之前永久代存什么数据,现在存到什么位置了?
JDK8 以后还有永久代么?如果有的话是在堆区么?之前永久代存什么数据,现在存到什么位置了?
如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。
绑定邮箱获取回复消息
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
JDK8 以后还有永久代么?如果有的话是在堆区么?之前永久代存什么数据,现在存到什么位置了?
由于您还没有绑定你的真实邮箱,如果其他用户或者作者回复了您的评论,将不能在第一时间通知您!
接受
或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
发布评论
评论(2)
首先,一直以来HotSpot JVM这个 JVM 实现中才有永久代的概念,其他JVM 实现并没有永久代的概念。是这样吧?
对于 HotSpot JVM:
JDK8 中把原来的方法区的永久代(PermGen)去掉了,将对应的数据移动到元空间 MetaSpace(处于方法区中)和 heap 中。原来永久代的字符串常量移动到了Java Heap,类的元数据(类的信息)移动到了元空间。
这个改动的原因或者说好处和元空间的特点有关。简单的说元空间是本地堆内存(native heap),这是系统直接内存,因为系统直接内存的资源更多,OOM 的可能性被降低。补充一句,元空间的上限由-XX:MaxMetaspaceSize来配置。
下面来聊聊元空间的垃圾回收和调优。如果Metaspace的空间占用达到了设定的最大值,那么就会触发GC来收集死亡对象和类的加载器。根据JDK 8的特性,G1和CMS都会很好地收集Metaspace区(一般都伴随着Full GC)。(调优)为了减少垃圾回收的频率及时间,控制吞吐量,对Metaspace进行适当的监控和调优是非常有必要的。如果在Metaspace区发生了频繁的Full GC,那么可能表示存在内存泄露或Metaspace区的空间太小了。
元空间相关的四个 JVM 参数和辅助监测和调优工具,见https://www.sczyh30.com/posts...。
HotSpot JVM才有永久代的概念,java8里去掉了。原来不在堆中,在一个特殊的方法区位置。