字节输入流的使用:
Java文件字节输入流有3种方式读取:
注:在开始之前,都要创建一个文件字节输入流管道 与源文件接通
//"file-io-app/src/data.txt"是文件的相对路径
//使用多态的写法 子类对象到父类类型
InputStream is = new FileInputStream("file-io-app/src/data.txt");
1.每次读取一个字节
//读取一个字节返回(每次读取一滴水)
//public int read():每读取一个字节(读完一个往后流动) 读取完毕会返回-1
//字节的范围在整数之内,int有4个字节 用int接不会出问题
int b;
while ((b = is.read()) != -1) {
//把字符编号转成char看字符内容
System.out.print((char)b);
}
- 每次读取一个字节数组(把每个字节数组当成一个桶)
byte[] buffer = new byte[3]; //定义桶的大小 一次3个字节
int len; //记录读取到的长度 读取不到返回-1
while ((len = is.read(buffer)) != -1) {
//new String(buffer, 0, len):0,len可以确保最后读取到2个字符的时候 不额外输出上一个流的内容
System.out.print(new String(buffer, 0, len));
}
- 一次读完全部字节
//2.定义一个字节数组与文件的大小一样大 可以一次输出所有内容
//方法1
byte[] buffer = new byte[(int) f.length()];
int len = is.read(buffer);
System.out.println(new String(buffer));
//方法2:JDK9才可使用
byte[] buffer = is.readAllBytes();
System.out.println(new String(buffer));
怎么让字节输入流读取中文内容输出不乱码:
- 一次性读取完全部字节(方法3)可以定义与文件一样大的字节数组读取。也可以使用官方API
- 有可能会出现内存溢出