Java,缓冲区延迟分配,按需可释放并作为byte []寻址

Mik*_* J. 5 java memory-management

我试图通过扩展现有的Java程序来实现概念验证内存感知调度功能.该程序使用缓冲区的形式byte [].因为我的目的byte []是有问题的,因为

  1. 他们是垃圾收集
  2. 它们被预先分配而不是懒惰(JVM似乎触及它在创建缓冲区时分配的所有页面)
  3. 它们使JVM分配越来越多的内存,而这些内存并没有返回给操作系统.

为了实现我的目标,我希望缓冲区是懒惰分配的内存(仅在写入时分配的页面)并且可以按需释放.这与C++中的情况类似.另外,尽可能地,我想尽量减少对现有代码库的更改.

我看着nio.ByteBuffer不安全的班级.不适合我的情况,因为

  1. java.nio.ByteBuffers似乎没有懒惰的分配.当我分配一个空的1GB缓冲区时,程序的RSS立即变为1GB.
  2. Unsafe.allocateMemory懒惰分配,但我不知道如何引用它byte [].

有什么方法可以解决这个问题吗?以任何方式查看分配的内存Unsafe.allocateMemory()byte []?或者将现有更改byte []为指向分配给Unsafe的内存?

谢谢

Pet*_*rey 0

Java 被设计为具有单独的内存区域。

  • 像 byte[] 这样的堆上,它被设计为可重新分配,并且被清零并且不懒惰。之所以会这样,是因为内存是被管理的。
  • 堆外的优点是它可以是惰性的,但它不能假装是像 byte[] 这样的托管数据类型。