字节流和字符流读取文件 使用read()方法 注意清空自定义char数组或byte数组
。。。byte[] buff = new byte[1024];
while(in.read(buff) > 0) {。。。
或
。。。char[] c = new char[100];
while(r.read(c) > 0) {。。。
read(buff)方法仅仅对 buff数组进行赋值,当最后一次读取,剩余的数据和数组长度不一致时,数组就会保留上一次读取的结果,在输出时造成误差。所以在使用read()方法时,应该在while循环里面重置数组,保证数据的准确性。
---------------------
。。。BufferedReader r = new BufferedReader(new FileReader(f));
String line = null;
while((line = r.readLine()) != null) {。。。
当使用readLine()方法时,每次都会重置String变量重新赋值给 自定义的line 所以没有这个问题。
下面是示例
------------------------------------------------------------------------------------------------
要读取的文件
代码如下:
File f = new File("C:\\Users\\Administrator\\Desktop\\git\\learngit\\a.txt");
if(!f.exists()) {
f.getParentFile().mkdirs();
f.createNewFile();
}
//字节流
InputStream in = new FileInputStream(f);
byte[] buff = new byte[1024];
while(in.read(buff) > 0) {
System.out.println(new String(buff));
}
in.close();
预期结果 应该是以一串数字结尾 ,现在结果是这样的:
现在加上 buff = new byte[1024]; ,结果就和预期一样了
//字节流
InputStream in = new FileInputStream(f);
byte[] buff = new byte[1024];
while(in.read(buff) > 0) {
System.out.println(new String(buff));
buff = new byte[1024];
}
in.close();