gpt4 book ai didi

Java DataInputStream 作用域

转载 作者:行者123 更新时间:2023-12-01 11:06:58 26 4
gpt4 key购买 nike

我正在尝试编写一个外部合并排序,但如果我已经关闭了第一个数据输入流,我似乎无法为文件创建第二个数据输入流。例如:

public class test {
private static DataInputStream createInputStream(RandomAccessFile f)
throws FileNotFoundException, IOException {
return new DataInputStream(new BufferedInputStream(new FileInputStream(
f.getFD())));
}
private static int readInt(RandomAccessFile file) throws IOException{
DataInputStream istream = createInputStream(file);
int i = istream.readInt();
istream.close();
return i;
}
public static void main(String[] args) throws IOException{
RandomAccessFile file = new RandomAccessFile(args[0], "rw");
for(int j = 0; j < 10; j++){
System.out.println(readInt(file));
}
}
}

当我运行这个程序时,我得到一个数字,但随后出现以下错误:

java.io.IOException: Stream Closed
at java.io.FileInputStream.readBytes(Native Method)
at java.io.FileInputStream.read(FileInputStream.java:255)
at java.io.BufferedInputStream.fill(BufferedInputStream.java:246)
at java.io.BufferedInputStream.read(BufferedInputStream.java:265)
at java.io.DataInputStream.readInt(DataInputStream.java:387)
at uk.ac.cam.av429.fjava.tick0.test.readInt(test.java:19)
at uk.ac.cam.av429.fjava.tick0.test.main(test.java:26)

如何为一个文件创建多个独立的流,还是必须使用单个流?

最佳答案

异常消息有点误导。问题很可能是当您关闭第一个流时,它会导致底层的 RandomAccessFile被关闭——或者至少是其底层的原生资源。

或者,第一个流也可能消耗从 RAF 当前位置到末尾的所有数据,因此没有任何内容可供读取。它将由于您插入 BufferedInputStream 而执行此操作进入流的嵌套 - BIS 应该提前读取以填充其缓冲区,并且当您关闭它时,缓冲的数据将丢失。

无论如何,你不应该这样做。与其每次都创建一个新流,不如创建一个流并重复使用它。只需从同一流中读取每个后续​​数据即可。

关于Java DataInputStream 作用域,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32851791/

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