操作堆外内存溢出

DirectMemory容量可通过-XX:MaxDirectMemorySize指定,如果不指定,则默认与JAVA堆的最大值(-Xmx指定)一样。

以下代码越过了DirectByteBuffer类,直接通过反射获取Unsafe实例并进行内存分配(Unsafe类的getUnsafe()方法限制类只有引导类加载器才会返回实例,也就是设计者希望只有rt.jar中的类才能使用Unsafe的功能)。因为,虽然使用DirectByteBuffer分配内存也会抛出内存溢出异常,但它抛出异常时并没有真正向操作系统申请分配内存,而是通过计算得知内存无法分配,于是手动抛出异常,真正申请分配内存的方式是unsafe.allocateMemory().

/**
 * VM args : -Xms20M -XX:MaxDirectMemorySize=10M
 *
 */
public class DirectMemoryOOM {
 private static final int _1MB = 1024 * 1024;

public static void main(String[] args) throws IllegalArgumentException, IllegalAccessException {
  Field unsafeField=Unsafe.class.getDeclaredFields()[0];
  unsafeField.setAccessible(true);
  Unsafe unsafe=(Unsafe) unsafeField.get(null);
  while(true){
   unsafe.allocateMemory(_1MB);
  }
 }
}

运行结果 :Exception in thread "main" java.lang.OutOfMemoryError

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/58f30b68e4ab93857021b8356317178b.html