代码:新手学IO
[code="java"]
package woca;
import java.io.BufferedInputStream;
import java.io.BufferedOutputStream;
import java.io.DataInputStream;
import java.io.DataOutputStream;
import java.io.FileInputStream;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.InputStream;
public class FilterOutputTester {
public static void main(String[] args) throws IOException {
FileOutputStream out1 = new FileOutputStream("D:\test.txt");
BufferedOutputStream out2 = new BufferedOutputStream(out1, 256);
DataOutputStream out = new DataOutputStream(out2);
out.writeUTF("你好啊");
out.writeUTF("再见");
out.close();
InputStream in1 = new FileInputStream("D:\\test.txt");
BufferedInputStream in2 = new BufferedInputStream(in1, 3);
DataInputStream in = new DataInputStream(in2);
System.out.println(in.readUTF());
in1.close();
}
}
[/code]
大家也能看到我往 D盘test里边先写入 了 字符"你好啊"又写入了"再见" 也写入进去了 但是读取出来的却只有[color=red]你好啊[/color]这是怎么回事啊?
谢谢了 ! 我实在是想不到答案了!
[quote]看看API 好像是 通过 writeShort 方法将两个字节写入输出流,表示后跟的字节数。 但是 还是不明白啊 后跟字节数是怎么回事?[/quote]
首先DataOutputStream 可以写出 字符串、数字等各种类型。这些内容反映到底层都是10的二进制。如何区分字符串和数字的边界?
你可以使用writeUTF的方式,写入字符串,但是,这个字符串到底有多长?必须有个长度的标识。
你自己的问题:在 [b]System.out.println(in.readUTF()); [/b]的后面再加上个
[color=red]System.out.println(in.readUTF()); [/color]就可以把所有的都输出来了。
关键你要明白 ReadUTF()只是读出一个字符串,你文件里面有两个字符串怎么能一下子读出来?是吧。
你少些了一个in.readUTF();
你的问题在于,你将in.readUTF的功能领悟错了。
in.readUTF()的功能,先要从out.writeUTF()说起:
writeUTF写出字符串时,先写出2个字节,表示后面的字符串的长度。然后,在将字符串编码为UTF-8写出。
in.readUTF读取时,先读取2个字节,转换成一个16位的整数,然后再读取该整数个字符。
分析你的例子:
你写入的文件大概是这样(示意图):
3(占2个字节)“你好啊”(占3个字符)2(占2个字节)“再见”
你只使用了一次in.readUTF,所以 先读取2个字节(整数3),然后读取3个字符,返回“你好啊”。所以后面的数据,没有被读入。
所以,你得在一次调用in.readUTF,才能读取到“再见”
[quote]表示后跟的字节数。 但是 还是不明白啊 后跟字节数是怎么回事?[/quote]
看看DataInputStream的read源码,就清楚了。。