我有一个大文件,我正在打开一个FileInputStream.此文件包含一些文件,每个文件都有一个从开头和大小的偏移量.此外,我有一个解析器,应该评估这样一个包含的文件.
File file = ...; // the big file
long offset = 1734; // a contained file's offset
long size = 256; // a contained file's size
FileInputStream fis = new FileInputStream(file );
fis.skip(offset);
parse(fis,size);
public void parse(InputStream is,long size) {
// parse stream data and insure we don't read more than size bytes
is.close();
}
我觉得这不是好习惯.有没有更好的方法来做到这一点,也许使用缓冲?
此外,我觉得skip()方法会大大减慢阅读过程.
解决方法
听起来你真正想要的是一种“部分”输入流 – 有点像ZipInputStream,你在流中有一个流.
您可以自己编写,将所有InputStream方法代理到原始输入流,对偏移量进行适当调整,并检查读取子文件末尾的内容.
那是你在谈论的那种事吗?