内存溢出(OOM)的原因
JVM的内存空间 : 堆、永久区、线程栈、直接内存
堆溢出:java.lang.OutOfMemoryError: Java heap space
解决方法:增大堆空间,及时释放内存
永久区溢出: Caused by: java.lang.OutOfMemoryError: PermGen space
解决方法:增大Perm区 允许Class回收
线程栈溢出: java.lang.OutOfMemoryError:unable to create new native thread
解决方法:减少堆内存,减少线程栈大小
直接内存 溢出 ByteBuffer.allocateDirect()无法从操作系统获得足够的空间
减少堆内存、有意触发GC
MAT使用基础
支配树
在对象引用图中,所有指向对象B的路径都经过对象A,
则认为对象A支配对象B
如果对象A是离对象B最近的一个支配对象,
则认为对象A为对象B的直接支配者
支配者被回收,被支配对象也被回收
浅堆(Shallow Heap)
一个对象结构所占用的内存大小
3个int类型以及一个引用类型合计占用内存3*4+4=16个字节。再加上对象头的8个字节,因此String对象占用的空间,即浅堆的大小是16+8=24字节
对象大小按照8字节对齐
浅堆大小和对象的内容无关,只和对象的结构有关
深堆(Retained Heap)
一个对象被GC回收后,可以真实释放的内存大小
只能通过对象访问到的(直接或者间接)所有对象的浅堆之和 (支配树)
显示入引用(incoming)和出引用(outgoing)