JDK8堆内存划分变化

时间:2022-03-17 14:06:46

     JVM中内存:堆内存、栈内存。栈内存主要用执行线程方法存放本地临时变量与线程中方法执行时候需要的引用对象地址。JVM所有的对象信息都存放在堆内存中,相比栈内存,堆内存可以所大的多,所以JVM一直通过对堆内存划分不同的功能区块实现对堆内存中对象管理。堆内存不够最常见的错误就是OOM(OutOfMemoryError),栈内存溢出最常见的错误就是*Error,程序有递归调用时候最容易发生。


     在JDK7以及其前期的JDK版本中,堆内存通常被分为三块区域Nursery内存(young 
generation)、长时内存(old generation)、永久内存(Permanent Generation for 
VM Matedata)。一个对象被创建后最先是放到新生代的伊甸区内存中,如果存活期超过两个survivor后会被转移至下PerGen中永久存活,但是当永久内存不够时,将报java.lang.OutOfMemoryError: PermGen ,但是在JDK8 中此情况不再发生,原因是:在于JDK8中把存放元数据中的永久内存从堆内存中移到了本地内存(native memory)
中,JDK8中JVM堆内存结构改变。


JDK8也提供了一个新的设置Matespace内存大小的参数,通过这个参数可以设置Matespace内存大小,这样我们可以根据自己项目的实际情况,避免过度浪费本地内存,达到有效利用。如果你设置的元内存空间过小,你的应用程序可能得到以下错误:
java.lang.OutOfMemoryError: Metadata space