共计 1397 个字符,预计需要花费 4 分钟才能阅读完成。
package com.itheima.demo02.InputStream;
import java.io.FileInputStream;
import java.io.IOException;
/*
字节输入流一次读取多个字节的方法:
int read(byte[] b) 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。明确两件事情:
1. 方法的参数 byte[] 的作用?
起到缓冲作用, 存储每次读取到的多个字节
数组的长度一把定义为 1024(1kb) 或者 1024 的整数倍
2. 方法的返回值 int 是什么?
每次读取的有效字节个数
String 类的构造方法
String(byte[] bytes) : 把字节数组转换为字符串
String(byte[] bytes, int offset, int length) 把字节数组的一部分转换为字符串 offset: 数组的开始索引 length: 转换的字节个数
*/
public class Demo02InputStream {
public static void main(String[] args) throws IOException {
// 创建 FileInputStream 对象, 构造方法中绑定要读取的数据源
FileInputStream fis = new FileInputStream("09_IOAndProperties\\b.txt");
// 使用 FileInputStream 对象中的方法 read 读取文件
//int read(byte[] b) 从输入流中读取一定数量的字节,并将其存储在缓冲区数组 b 中。/*byte[] bytes = new byte[2];
int len = fis.read(bytes);
System.out.println(len);//2
//System.out.println(Arrays.toString(bytes));//[65, 66]
System.out.println(new String(bytes));//AB
len = fis.read(bytes);
System.out.println(len);//2
System.out.println(new String(bytes));//CD
len = fis.read(bytes);
System.out.println(len);//1
System.out.println(new String(bytes));//ED
len = fis.read(bytes);
System.out.println(len);//-1
System.out.println(new String(bytes));//ED*/
/*
发现以上读取时一个重复的过程, 可以使用循环优化
不知道文件中有多少字节, 所以使用 while 循环
while 循环结束的条件, 读取到 - 1 结束
*/
byte[] bytes = new byte[1024];// 存储读取到的多个字节
int len = 0; // 记录每次读取的有效字节个数
while((len = fis.read(bytes))!=-1){//String(byte[] bytes, int offset, int length) 把字节数组的一部分转换为字符串 offset: 数组的开始索引 length: 转换的字节个数
System.out.println(new String(bytes,0,len));
}
// 释放资源
fis.close();}
}
正文完
发表至: java
2019-08-16