gpt4 book ai didi

java - mappingsize 或 limit 如何影响 MappedByteBuffer 性能?

转载 作者:塔克拉玛干 更新时间:2023-11-02 08:30:25 27 4
gpt4 key购买 nike

我正在处理大文件,我正在使用 MappedByteBuffer 进行读写操作。我有点缺乏知识,所以我想知道一些事情。

MappedByteBuffer buf = raf.getChannel().map(FileChannel.MapMode.READ_WRITE, offset, size);

  1. 我知道 ByteBuffer 的大小限制是 Integer.MAX_VALUE 那么我应该如何设置 MappedByteBuffer 的大小?我应该使用小块还是 Integer.MAX_VALUE?

    那么,如果我增加映射大小,我的应用程序读取和写入性能是否也会提高?

  2. 当这个大小增加时,我的内存使用量是否也在增加?我想知道这是因为我正在创建多个文件来读写。所以也许如果一个文件分配 2gb 的内存,如果我有 6 个文件我需要 12gb 的内存或者我的想法是完全错误的。

  3. 是和JVM -Xmx 还是我的物理内存有关?

这是我的用法:

    List<MappedByteBuffer> mappings = new ArrayList<MappedByteBuffer>();

int mSize = 25;

long MAPPING_SIZE = 1 << mSize;

File file = File.createTempFile("test", ".dat");
RandomAccessFile raf = new RandomAccessFile(file, "rw");
ByteOrder byteOrder = java.nio.ByteOrder.nativeOrder(); // "LITTLE_ENDIAN";

try {
long size = 8L * width * height;
for (long offset = 0; offset < size; offset += MAPPING_SIZE) {
long size2 = Math.min(size - offset, MAPPING_SIZE);
MappedByteBuffer buf = raf.getChannel().map(FileChannel.MapMode.READ_WRITE, offset, size2);
buf.order(byteOrder);
mappings.add(buf);
}
}

最佳答案

  1. 简短回答是,如果您知道您的文件将比 2g 大很多。唯一的缺点是您的磁盘空间使用:如果您使用较大的增量,如果 size 不是 MAPPING_SIZE 的倍数,则浪费的磁盘空间量会更大。

  2. 只有您的虚拟内存使用量在增加。除非你在 32 位机器上,否则这应该不是问题。 Linux 上的最大虚拟内存为 128TiB,因此您还有一些空间。如果您需要比这更多的虚拟内存,您将需要寻求另一种解决方案。内存映射文件使用页面缓存:操作系统只会在使用文件时逐页 [1] 加载物理内存中的文件,并在可用物理 RAM 变紧时卸载这些页面。

  3. 没有。参见 2。

对于一些额外的资源,这里有一个关于页面缓存如何工作的很好的总结:Page Cache, the Affair Between Memory and Files

[1]: 页面是一个OS级的内存单元,一般为4KiB

关于java - mappingsize 或 limit 如何影响 MappedByteBuffer 性能?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/57889269/

27 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com