[英]RandomAccessFile unexpected behavior for seek and write or write with offset
我不明白两者之间有什么区别
RandomAccessFile raf = new RandomAccessFile(file, "rw");
int offset = getOffset();
byte[] dataInBytes = getData();
raf.seek(offset);
raf.write(dataInBytes, 0, getSize())'
和
...
byte[] dataInBytes = getData();
raf.write(dataInBytes, offset, getSize());
我以为先查找然后写等同于使用偏移量而不是零的写函数。 但似乎并非如此。 我不知道有什么区别,我只需要通过单元测试,第二个版本可以通过单元测试,而第一个版本则不需要。
这两种方法有什么区别?
查看RandomAccessFile#write(byte []。int,int)的JavaDoc:
从指定的字节数组开始将len个字节从offset偏移量写入此文件。
参数 :
b
数据。
off
数据中的起始偏移量。
len
要写入的字节数。
传递给write(byte[], int, int)
的offset参数不是文件的偏移量,而是传递给字节数组的偏移量。
您的第一个代码段将RandomAccessFile
放置在位置offset
,然后从该位置的数据数组的开头写入getSize()
字节。
您的第二个代码段不更改RandomAccessFile
的位置(这可能意味着开始在文件的开头进行写入),然后写入数据数组的getSize()
字节,从字节数组中位置offset
的字节开始。
在前者中,偏移量位于您正在访问的文件中。 在后面,它是数组的偏移量。
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.