JVM从永久代至元空间内存结构变化图
变化后的java8图
变化之前java7以及之前各代的图
看出变化了吗?堆和方法区连在了一起,但这并不能说堆和方法区是一起的,它们在逻辑上依旧是分开的。但在物理上来说,它们又是连续的一块内存。也就是说,方法区和前面讲到的新生代和老年代是连续的。
方法区与永久代和元空间两者关系
可以将方法区当作接口,永久代和元空间实现了这个接口。
只不过两者一个是旧的,java8之前时代的实现。
一个是新的,java8时代的实现。
永久代为什么会被替换
- 内存泄漏:持久代中的类信息不会被垃圾回收,如果应用程序长时间运行,持久代中的空间可能会被占满,导致内存泄漏。
- GC效率低下:由于持久代的对象不会被垃圾回收,垃圾回收器需要扫描整个持久代,导致GC效率低下。
- 上限问题:PermGen区的大小是有限制的,如果应用程序中使用的类太多,可能会导致PermGen区被占满,导致应用程序崩溃。
因此,为了解决这些问题,JVM引入了元数据区(MetaSpace)来存储类的元数据。元数据区不再采用固定大小的内存空间,而是根据应用程序的需要进行动态分配和扩展。另外,元数据区的对象可以被垃圾回收,避免了持久代的内存泄漏问题。这样,元数据区的引入提高了Java应用程序的稳定性和性能。