ByteBuffer.allocateDirect() 和 MappedByteBuffer.load() 之间的区别
我试图通过使用内存映射特定文件来实现两个或多个JVM之间的共享缓存。从规范中我看到,当我们使用它时,它应该将数据加载到直接缓冲区中。我对此有几个问题。MappedByteBuffer
MappedByteBuffer.load()
我的代码片段::
RandomAccessFile file = new RandomAccessFile("file.txt","rw");
FileChannel fc = file.getChannel();
MappedByteBuffer buf5 = fc.map(MapMode.READ_WRITE, 0, fc.size());
//ByteBuffer buf6 = ByteBuffer.allocateDirect(100000000);
buf5.load();
try
{
Class c = Class.forName("java.nio.Bits");
Field f = c.getDeclaredField("reservedMemory");
f.setAccessible(true);
long reservedMemory = f.getLong(null);
f = c.getDeclaredField("maxMemory");
f.setAccessible(true);
System.out.println(
"Direct Memory Usage: "+ reservedMemory +"/"+ f.getLong(null)+"\n");
}
catch (Throwable t)
{
}
-
上述代码的输出为 0 字节,表示直接内存使用情况(文件.txt为 1 GB)。但是,如果我取消注释该行..
ByteBuffer buf6 = ByteBuffer.allocateDirect(100000000);
我得到的直接内存使用量为100MB。无法理解为什么会这样,至于为什么我一开始就没有得到任何直接的内存使用(即当行被注释掉时)
虽然上述代码的直接内存使用量为0 B,但我确实看到进程的驻留内存(使用unix top)增加了1 GB。但是,如果我在框中做一个“free -m”,我没有看到内存使用量的任何增加。
在这两种情况下,我对记忆的结束位置有点困惑。
谢谢!