MappedByteBuffer 抛出 java.nio.BufferOverflowException
MappedByteBuffer throwing a java.nio.BufferOverflowException
我正在学习 java nio,我正在使用 MappedByteBuffer 和 ExecutorService 异步复制文件。我的问题是方法 MappedByteBuffer.put() 抛出 java.nio.BufferOverflowException。但是在我的调试中,我没有复制到我的目标文件上的 over 位置。这是我用来创建文件新副本的代码部分:
for (Future<?> f : futures) {
Message message = (Message) f.get();
try (FileChannel fileChannel = (FileChannel) Files
.newByteChannel(pathWrite, EnumSet.of(
StandardOpenOption.READ,
StandardOpenOption.WRITE,
StandardOpenOption.TRUNCATE_EXISTING))) {
MappedByteBuffer mbb = fileChannel.map(
FileChannel.MapMode.READ_WRITE, message.getCod(),
message.getValue());
if (mbb != null) {
System.out.println("start: " + message.getCod()
+ " - end: " + message.getValue());
ByteBuffer encode = Charset.forName(charEncoding)
.encode(message.getCharBuffer());
mbb.put(encode); // here
}
} catch (IOException ioe) {
ioe.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
例外情况是:
java.nio.BufferOverflowException
at java.nio.DirectByteBuffer.put(DirectByteBuffer.java:363)
at java.nio.DirectByteBuffer.put(DirectByteBuffer.java:342)
at memo.MultiThreadingMappedByteBufferExample.multiThreadedWayWithExecutorService(MultiThreadingMappedByteBufferExample.java:139)
您正在将文件截断为零长度,根据 message.getCod()
和 message.getValue()
提供的偏移量和长度值映射它的一些未知部分,因为文件不存在长度为零,然后尝试将消息提供的 charBuffer
放入文件中,该文件的长度仍然为零,位于 message.getCod()
定义的偏移量处,该偏移量不存在,因此您得到BufferOverflowException
.
我建议您不要一开始就截断文件,但尚不清楚为什么这样做会奏效。我建议你使用 RandomAccessFile
。更简单。您不应该在单个应用程序中使用大量内存映射文件,仅将其用于这个小工作是不合适的。
我正在学习 java nio,我正在使用 MappedByteBuffer 和 ExecutorService 异步复制文件。我的问题是方法 MappedByteBuffer.put() 抛出 java.nio.BufferOverflowException。但是在我的调试中,我没有复制到我的目标文件上的 over 位置。这是我用来创建文件新副本的代码部分:
for (Future<?> f : futures) {
Message message = (Message) f.get();
try (FileChannel fileChannel = (FileChannel) Files
.newByteChannel(pathWrite, EnumSet.of(
StandardOpenOption.READ,
StandardOpenOption.WRITE,
StandardOpenOption.TRUNCATE_EXISTING))) {
MappedByteBuffer mbb = fileChannel.map(
FileChannel.MapMode.READ_WRITE, message.getCod(),
message.getValue());
if (mbb != null) {
System.out.println("start: " + message.getCod()
+ " - end: " + message.getValue());
ByteBuffer encode = Charset.forName(charEncoding)
.encode(message.getCharBuffer());
mbb.put(encode); // here
}
} catch (IOException ioe) {
ioe.printStackTrace();
} catch (Exception e) {
e.printStackTrace();
}
}
例外情况是:
java.nio.BufferOverflowException
at java.nio.DirectByteBuffer.put(DirectByteBuffer.java:363)
at java.nio.DirectByteBuffer.put(DirectByteBuffer.java:342)
at memo.MultiThreadingMappedByteBufferExample.multiThreadedWayWithExecutorService(MultiThreadingMappedByteBufferExample.java:139)
您正在将文件截断为零长度,根据 message.getCod()
和 message.getValue()
提供的偏移量和长度值映射它的一些未知部分,因为文件不存在长度为零,然后尝试将消息提供的 charBuffer
放入文件中,该文件的长度仍然为零,位于 message.getCod()
定义的偏移量处,该偏移量不存在,因此您得到BufferOverflowException
.
我建议您不要一开始就截断文件,但尚不清楚为什么这样做会奏效。我建议你使用 RandomAccessFile
。更简单。您不应该在单个应用程序中使用大量内存映射文件,仅将其用于这个小工作是不合适的。