我想将最后10MB的可能大文件复制到另一个文件中。理想情况下,我会使用FileInputStream,skip()然后read()。但是我不确定skip()的性能是否会很糟糕。 skip()通常是使用下面的文件搜索实现的,还是实际读取和丢弃数据?
我知道RandomAccessFile,但我对是否可以使用FileInputStream代替它感兴趣(RandomAccessFile很烦人,因为API是非标准的)。
答案 0 :(得分:17)
取决于您的JVM,但这是最近openjdk FileInputStream.skip()
的来源:
JNIEXPORT jlong JNICALL
Java_java_io_FileInputStream_skip(JNIEnv *env, jobject this, jlong toSkip) {
jlong cur = jlong_zero;
jlong end = jlong_zero;
FD fd = GET_FD(this, fis_fd);
if (fd == -1) {
JNU_ThrowIOException (env, "Stream Closed");
return 0;
}
if ((cur = IO_Lseek(fd, (jlong)0, (jint)SEEK_CUR)) == -1) {
JNU_ThrowIOExceptionWithLastError(env, "Seek error");
} else if ((end = IO_Lseek(fd, toSkip, (jint)SEEK_CUR)) == -1) {
JNU_ThrowIOExceptionWithLastError(env, "Seek error");
}
return (end - cur);
}
看起来它在做seek()
。但是,我不明白为什么RandomAccessFile
是非标准的。它是java.io
包的一部分,从1.0开始。
答案 1 :(得分:0)
您将对此LINK
感兴趣它说寻求比跳过更快