gpt4 book ai didi

java - 扩展阅读器,如何返回我的 "read"?

转载 作者:搜寻专家 更新时间:2023-10-31 20:19:10 25 4
gpt4 key购买 nike

作为我的 Java 类(class)的一部分,我编写了一个“zip”写入器和读取器 - 作为霍夫曼算法的工作原理。

我的类扩展了 Reader,并有一个对象 Reader r。在我的主要方法中,我有这些行:

input = new BufferedReader(new HuffmanReader(new FileReader("output.hff")));
String str = input.readLine();

当然,它应该在解压后返回我写入文件的解压字符串。但它返回文件的第一行!

我的阅读功能:

public int read(char[] cbuf, int off, int len) throws IOException {
//...
r.read(buffer,0,8192)
//does the decompress process
String fnlStr = ... //The final result
cbuf = fnlStr.toCharArray();
//close streams
return cbuf.length;
}

我的调试窗口显示如下:

HuffmanReader.read(char[], int, int) line: 23   
BufferedReader.fill() line: not available
BufferedReader.readLine(boolean) line: not available
BufferedReader.readLine() line: not available
Run.main(String[]) line: 23

它调用了我的读取函数两次。如何阻止 bufferReader 再次调用 read 函数?

最佳答案

您不会像往常一样返回从方法中读取的数据。相反,当 read 被调用时,调用者给你数组 cbuf,它本质上是一 block 内存的地址,并告诉你写 len char 放入其中。

当您执行 cbuf = fnlStr.toCharArray() 时,您只是将该地址的本地副本替换为另一个地址,但实际上并没有更改您应该写入的内存到。您需要遍历 for 循环中给定的数组并写入它,或者使用 System.arraycopy如果您构建了另一个包含结果的缓冲区。

例如,下面的read 方法将始终读取"Test\n":

public int read(char[] cbuf, int off, int len) throws IOException {
char[] result = "Test\n".toCharArray();
int numRead = Math.min(len, result.length);
System.arraycopy(result, 0, cbuf, off, numRead);
return numRead;
}

"Test\n" 文字替换为解压缩的字符串应该可以让您开始。当然,您仍然需要管理已经消耗了多少资源。


至于 BufferedReader 调用 read 两次:您不应该关心它被调用的频率。只需从您的底层源获取数据,将其写入 cbuf 并返回您写入的 char 的数量。如果没有任何内容可读,则返回 -1 以表示流结束(在这种情况下 BufferedReader 将停止调用 read)。


顺便说一句,Reader 用于读取字符流,而 InputStream is for binary data (它基本上是同一件事,只是使用 byte[] 而不是 char[] 并且不使用字符集)。由于压缩文件是二进制文件,您可能希望将 FileReader 切换为 FileInputStream

如果出于某种原因,你编码的字符集与你解码的字符集不同,我可以想象出奇怪的错误。或者不太戏剧性的是,如果 UTF-16 中的一个 16 位代码单元需要 UTF-8 中的 3 个 8 位代码单元,您可能会使用比您想象的更多的空间。

关于java - 扩展阅读器,如何返回我的 "read"?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/29977944/

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