IO流总结

1,什么是IO流
Java中的IO流是输入输出流。至于理解,可以将输入和输出两个端点看作是两个工厂,工厂之间需要互相运输货物,而流则是两工厂之间的公路,没有公路就不能互相运输,至于字符,字节和二进制则可以看作是运输的方式和单位大小,比如说把二进制理解成三轮车,那么字节就是小卡车,而字符则是集卡之类的。

2,如何实现IO
Java.io下面有两个抽象类:InputStream和Reader
InputStream是表示字节输入流的所有类的超类 Reader是用于读取字符流的抽象类
InputStream提供的是字节流的读取 Reader文本读取,这是和Reader类的根本区别。
用Reader读取出来的是char数组或者String 用InputStream读取出来的是byte数组。

使用FileInputStream读取文件数据的步骤:
1、找到目标文件。
2、建立数据的输入通道。
3、读取文件中的数据。
4、关闭资源。
四种读取数据的方法:

读取的方式一,缺陷: 无法读取完整一个文件的数据。
public static void readTest1() throws IOException{
//1. 找到目标文件
File file = new File(“F:\a.txt”);
//建立数据的输入通道。
FileInputStream fileInputStream = new FileInputStream(file);
//读取文件中的数据
int content = fileInputStream.read();
// read() 读取一个字节的数据,把读取的数据返回。
System.out.println(“读到的内容是:”+ (char)content);
//关闭资源 实际上就是释放资源。
fileInputStream.close();
}

方式2 : 使用循环读取文件的数据。
public static void readTest2() throws IOException{
long startTime = System.currentTimeMillis();
//找到目标文件
File file = new File(“E:/180192541/FileRecv/DSC_0007.JPG”);
//建立数据的输入通道
FileInputStream fileInputStream = new FileInputStream(file);
//读取文件的数据
int content = 0; //声明该变量用于存储读取到的数据
while((content = fileInputStream.read())!=-1){
System.out.print((char)content);
}
//关闭资源
fileInputStream.close();
long endTime = System.currentTimeMillis();
System.out.println(“读取的时间是:”+ (endTime-startTime));
}

方式3:使用缓冲数组读取,缺点: 无法读取完整一个文件的数据。
public static void readTest3() throws IOException{
//找到目标文件
File file = new File(“F:\a.txt”);
//建立数据的输入通道
FileInputStream fileInputStream = new FileInputStream(file);
//建立缓冲字节数组,读取文件的数据。
byte[] buf = new byte[1024];
//相当于超市里面的购物车。
// 如果使用read读取数据传入字节数组,那么数据是存储到字节数组中的,而这时候read方法的返回值是表示的是本次读取了几个字节数据到字节数组中。
System.out.println(“length:”+ length);
//使用字节数组构建字符串
String content = new String(buf,0,length);
System.out.println(“内容:”+ content);
//关闭资源
fileInputStream.close();
}

方式4:使用缓冲数组配合循环一起读取。
public static void readTest4() throws IOException{
long startTime = System.currentTimeMillis();
//找到目标文件
File file = new File(“E:/180192541/FileRecv/DSC_0007.JPG”);
//建立数据的输入通道
FileInputStream fileInputStream = new FileInputStream(file);
//建立缓冲数组配合循环读取文件的数据。
//保存每次读取到的字节个数。
byte[] buf = new byte[1024];
//存储读取到的数据缓冲数组的长度一般是1024的倍数,因为与计算机的处理单位。理论上缓冲数组越大,效率越高
while((length = fileInputStream.read(buf))!=-1){
// read方法如果读取到了文件的末尾,那么会返回-1表示。
System.out.println(length);
System.out.print(new String(buf,0,length));
}
//关闭资源
fileInputStream.close();
long endTime = System.currentTimeMillis();
System.out.println(“读取的时间是:”+ (endTime-startTime));
}

第一种和第三种有一定的缺陷不建议使用,所以一般使用第二种和第四种,但是大家应该注意到了其中的currentTimeMillis()方法了,通过这种方法得出了第四种比第一种的效率高,输入数据数据快,尤其文件越大,效果越明显。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值