DirectMemory容量可通过-XX:MaxDirectMemorySize指定,如果不指定,则默认和Java堆最大值(-Xmx)一样。代码如下:
import java.lang.reflect.Field;
import sun.misc.Unsafe;
/**
* VM args:-Xmx20M -XX:MaxDirectMemorySize=10M
* test:使用unsafe分配本机内存
*/
public class DirectMemoryOOM {
private static final int _1MB = 1024 * 1024;
public static void main(String[] args) throws Exception {
Field unsafeField = Unsafe.class.getDeclaredFields()[0];
unsafeField.setAccessible(true);
Unsafe unsafe = (Unsafe) unsafeField.get(null);
while (true) {
unsafe.allocateMemory(_1MB);
}
}
}
由DirectMemory导致的内存溢出,一个明显的特征就是再Heap Dump文件中不会看见明显的异常,如果读者发现OOM之后Dump文件很小,而程序中又直接或间接的使用了NIO,那就可以考虑检查一下是不是这方面的原因。