IO流:数据传输是需要通道的,而IO流就是数据传输的通道。

    IO流可以形象的比喻为运送货物的传输带。

IO流的分类:

  ①根据操作的数据类型的不同可以分为 :字节流与字符流。

  ②根据数据的流向分为:输入流与输出流,程序(内存)作为参照物,程序从外部读取称为输入(Input),程序向外部写数据成为输出(Output)。

字节输入流:

父类:InputStream

 常用的字节输入流:FileInputStream

1.FileInputStream

①构造方法:

  FileInputStream(File)

  FileInputStream(String  filename)

2.常用方法 

  ①read :读取一个字节,返回该字节的值,如果到达文件的末尾,则返回-1。需要注意:read()方法和迭代器一样,会自动下移的

  ②read(byte[ ])从输入流中读取至多一个数组长度的内容,到达文件末尾,则返回-1。    

  • 数组称为缓冲区数组,大小一般取值为1024的整数倍。
  • 转换为字符时,使用String(byte [ ]   bytes,int offset,int length)
  • available()没有读取的剩余字节数,如果该文件还从未被读取,就返回该文件的长度。
  • close() 关闭流并释放资源

字节输入流代码演示:

其中1.txt位于本项目的根目录下:内容为"abcdefg"

 1 import java.io.File;
2 import java.io.FileInputStream;
3 import java.io.IOException;
4
5 public class Demo6 {
6
7 public static void main(String[] args) throws IOException{
8 File file=new File("1.txt"); //新建一个文件的抽象路径
9 FileInputStream fis=new FileInputStream(file);
10 int result=fis.read();
11 System.out.println(result);
12
13 }
14
15 }

程序执行的结果为97,因为读取的a的ASCII码值

字节输入流的循环读取:

 1 import java.io.File;
2 import java.io.FileInputStream;
3 import java.io.IOException;
4
5 public class Demo7 {
6
7 public static void main(String[] args) throws IOException{
8 File file =new File("1.txt");
9 FileInputStream fis=new FileInputStream(file);
10 int result;
11 while((result=fis.read())!=-1) {
12 System.out.print(result+"\t");
13 }
14
15
16 }
17
18 }

打印了a到g的ASCII码值

字符流的读取方法:

 1 import java.io.File;
2 import java.io.FileInputStream;
3 import java.io.IOException;
4
5 public class Demo8 {
6
7 public static void main(String[] args) throws IOException{
8 File file =new File("1.txt");
9 FileInputStream fis=new FileInputStream(file);
10 byte[] bt=new byte[1024];
11 int count;
12 while((count=fis.read(bt))!=-1) {
13 String string =new String(bt,0,count);
14 System.out.println(string);
15 }
16 }
17 }

输出结果

下面可以用同样的文件来比较字节输入流和字符输入流的读取速度:

文件是一张格式为png图片

先是字节输入流的读取速度

 1 import java.io.File;
2 import java.io.FileInputStream;
3 import java.io.IOException;
4
5 public class Demo9 {
6
7 public static void main(String[] args) throws IOException{
8 File file =new File("D:\\Java代码\\123.png");
9 FileInputStream fis=new FileInputStream(file);
10 int count;
11 long start=System.currentTimeMillis();
12 while((count=fis.read())!=-1) {
13 System.out.println(count);
14 }
15 long end=System.currentTimeMillis();
16 System.out.println("======下面是所用的时间======");
17 System.out.println(end-start);
18 }
19
20 }

结果如下:

下面是字符输入流:

 1 import java.io.File;
2 import java.io.FileInputStream;
3 import java.io.IOException;
4
5 public class Demo10 {
6
7 public static void main(String[] args) throws IOException {
8 File file=new File("D:\\Java代码\\123.png");
9 FileInputStream fis=new FileInputStream(file);
10 byte[] bt=new byte[1024];
11 int count;
12 long start=System.currentTimeMillis();
13 while((count=fis.read(bt))!=-1) {
14 System.out.println(count);
15 }
16 long end=System.currentTimeMillis();
17 System.out.println("======下面是所用的时间======");
18 System.out.println(end-start);
19 }
20 }

结果如下:

字节输入流读取文件花费了760毫秒,而字符输入流读取文件花费了3毫秒,由此可见,字符输入流的速度要比字节输入流更快。

文件字节输出流:

字节输出流:OutputStream  是所有输出流的超类

常用子类:FileOutputStream  文件字节输出流

构造方法:

    FileOutputStream(File file) /FileOutputStream(String name)

  注意:如果父目录不存在,会报FileNotFoundException异常,如果父目录存在,会创建一个新的文件,如果此时已经有文件存在,会覆盖原文件

   FileOutputStream(File file,boolean flag)/FileOutputStream(String name,boolean flag)

  注意:如果当前文件需要从文件末尾进行插入(接着文件里的内容继续写),必须将第二个参数设置为true,默认不写为false,会覆盖原文件

常用方法:

  write(int)向文件中写入一个字节的值

  write(byte[]) 向文件中写入一个数组的数据。

  ***③ write(byte[] offset len) 将 偏移量为 offset 的索引位置的长度为 len 的数据,写入到输出流中。

代码示例:

 1 import java.io.File;
2 import java.io.FileOutputStream;
3 import java.io.IOException;
4
5 public class Demo11 {
6
7 public static void main(String[] args) throws IOException {
8 File file=new File("3.txt");
9 FileOutputStream fos=new FileOutputStream(file);
10
11 fos.write("没有绝对的绝缘体,只有不努力的电压。".getBytes());
12 }
13 }

执行结果,会在本项目的根目录下生成一个3.txt 文件,并且将内容写入进去。

文件复制:将一个文件通过IO流复制到另一个文件中去

代码示例:

 1 import java.io.File;
2 import java.io.FileInputStream;
3 import java.io.FileOutputStream;
4 import java.io.IOException;
5
6 public class Demo12 {
7
8 public static void main(String[] args) throws IOException {
9 File file=new File("1.txt");
10 FileInputStream fis=new FileInputStream(file);
11 FileOutputStream fos=new FileOutputStream(new File("4.txt"));
12 byte[] bt=new byte[1024];
13 int count;
14 while((count=fis.read(bt))!=-1) {
15 fos.write(bt,0,count);
16 }
17 fis.close();
18 fos.close();
19 }
20 }

结果会将1.txt的内容复制到4.txt中

带缓冲区的字节流
1. 通过比较 read() 与 read(byte[]) 的方法复制文件的时间的长短,可以看出,带缓冲区的读写文件的速度快,
java 上提供了专门带缓冲区的字节流,用以提高读写速度。
2.BufferedInputStream /BufferedOutputStream 带缓冲区的字节输入 / 输出流
3. 结论: 带缓冲区的字节流 读取速度高于字节流
代码演示:

 1 public class  带缓冲区的字节流 {
2 public static void main(String[] args) throws IOException {
3 /*FileInputStream fis=new FileInputStream(new File("src\\com\\ 文件复制 .java"));
4 // 复制操作 :
5 BufferedInputStream bis=new BufferedInputStream(fis);*/
6 // // 读取
7 // BufferedInputStream bis=new BufferedInputStream(new FileInputStream(new File("src\\com\\ 文
8 件复制 .java")));
9 // // 写入
10 // BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(new File("1.java"))
11 );
12 // 读取
13 BufferedInputStream bis=new BufferedInputStream(new FileInputStream(new File("D:\\0318java 班
14 \\day08\\ 录屏 \\1_day08IO 流概述 .mp4")));
15 // 写入
16 BufferedOutputStream bos=new BufferedOutputStream(new FileOutputStream(new File("C:\\Users\\
17 Administrator\\Desktop\\2.mp4")));
18 byte[] bt=new byte[1024];
19 int count=0;
20 long start=System.currentTimeMillis();
21 while((count=bis.read(bt))!=-1) {
22 bos.write(bt, 0, count);
23 }
24 long end=System.currentTimeMillis();
25 System.out.println(end-start);
26 bis.close();
27 bos.close();
28 }
29 }

jdk1.6 流的异常处理
1. 异常处理方式:
① try-catch-finally 异常的捕获
② throws 异常的声明
2. 以文件复制的形式来写流的异常处理 :
在 1.7jdk 之前包括 1.6 不包含 1.7 的流的异常处理形式。
代码演示:

 1 public class  字节流的异常处理方式 {
2 public static void main(String[] args) {
3 // 为了在 finally 里面能够使用关闭资源,提升作用域
4 FileInputStream fis=null;
5 FileOutputStream fos=null;
6 try {
7 // 输入流
8 fis=new FileInputStream(new File("src\\com\\ 带缓冲区的字节流 .java"));
9 // 输出流
10 fos=new FileOutputStream(new File("2.java"));
11 // 文件复制
12 byte[] bt=new byte[1024];
13 int count=0;
14 while((count=fis.read(bt))!=-1) {
15 fos.write(bt,0,count);
16 }
17 }catch(Exception e) {
18 e.printStackTrace();
19 }finally {
20 close(fis, fos);
21 }
22 }
23 public static void close(InputStream fis,OutputStream fos) {
24 // 关闭资源
25 try {
26 // 为了防止空指针,需要判断不为 null 再关闭
27 if (fis!=null) {
28 fis.close();
29 }
30 } catch (IOException e) {
31 // TODO Auto-generated catch block
32 e.printStackTrace();
33 }
34 try {
35 // 为了防止空指针,需要判断不为 null 再关闭
36 if (fos!=null) {
37 fos.close();
38 }
39 } catch (IOException e) {
40 // TODO Auto-generated catch block
41 e.printStackTrace();
42 }
43 }
44 }

Jdk1_7 流的异常处理形式

 1 public class Jdk1_7 流的异常处理形式 {
2 public static void main(String[] args) {
3 try(
4 FileInputStream fis=new FileInputStream(new File("src\\com\\ 带缓冲区的字节流 .java"));
5 FileOutputStream fos=new FileOutputStream(new File("3.java"));
6 ){
7 /*Scanner sc=new Scanner(System.in);
8 sc.close();*/
9 byte[] bt=new byte[1024];
10 int count=0;
11 while((count=fis.read(bt))!=-1) {
12 fos.write(bt,0,count);
13 }
14 }catch (Exception e) {
15 e.printStackTrace();
16 }
17 Scanner sc1=new Scanner(System.in);
18 String name = sc1.nextLine();
19 }
20 }
 

JAVA中IO流详解的更多相关文章

  1. Java之IO流详解

    IO流 Input/Output 完成输入/输出 应用程序运行时——数据在内存中  ←→ 把数据写入硬盘(磁带)  内存中的数据不可持久保存的  输入:从外部存储器(硬盘.磁带.U盘)把数据读入内存. ...

  2. java之IO流详解(一)

    IO流的分类: A:流向 输入流 读取数据 输出流 写出数据 B:数据类型 字节流 字节输入流  InputStream 字节输出流  OutputStream 字符流 字符输入流  Reader 字 ...

  3. java中io的详解

    注:本文全篇转载于:http://blog.csdn.net/taxueyingmei/article/details/7697042,觉得讲的挺详细,就借过来看看,挺不错的文章. 先贴一张图 Jav ...

  4. java之IO流详解(二)

    好了,昨天讲了字节流,现在我们就来讲字符流吧... 字符流可以这样理解,字符流 = 字节流 + 编码表,目的是为了更好的操作中文字符(注:字符流只可以可以操作字符类型的文件,不能操作影音图像文件,要操 ...

  5. [转载]java中import作用详解

    [转载]java中import作用详解 来源: https://blog.csdn.net/qq_25665807/article/details/74747868 这篇博客讲的真的很清楚,这个作者很 ...

  6. Java中日志组件详解

    avalon-logkit Java中日志组件详解 lanhy 发布于 2020-9-1 11:35 224浏览 0收藏 作为开发人员,我相信您对日志记录工具并不陌生. Java还具有功能强大且功能强 ...

  7. Java中IO流的总结

    有关Java中IO流总结图 流分类 按方向分 输入流 输出流 按单位分 字节流 字符流 按功能分 节点流 处理流(过滤流) 其他 所有的流继承与这四类流:InputSteam.OutputStream ...

  8. java中的注解详解和自定义注解

    一.java中的注解详解 1.什么是注解 用一个词就可以描述注解,那就是元数据,即一种描述数据的数据.所以,可以说注解就是源代码的元数据.比如,下面这段代码: @Override public Str ...

  9. Java中dimension类详解

    Java中dimension类详解 https://blog.csdn.net/hrw1234567890/article/details/81217788

随机推荐

  1. 移动端和web端的性能指标

    移动端的性能指标: 1.内存:80% 2.CPU 3.流量 4.电量 5.启动速度 6.滑动速度.界面切换速度 7.与服务器交互的网络速度 web端的性能指标: 1.CPU 2.内存 3.网络 4.I ...

  2. VM15 Ubuntu18.04下固定IP

    输入su 进入root用户 为下面修改文件内容提供权限 1.查看自己网卡名称:输入命令: ifconfig -a 或者 ip link 或者 ip addr 所以我的网卡名称是:ens33 2. 然后 ...

  3. kafka监听出现的问题,解决和剖析

    问题如下: kafka为什么监听不到数据 kafka为什么会有重复数据发送 kafka数据重复如何解决 为什么kafka会出现俩个消费端都可以消费问题 kafka监听配置文件 一. 解决问题一(kaf ...

  4. MacBook键盘锁定、按键失效、无反应等问题

    目录 MacBook按键无反应 u,i,o,j,k,l等键失灵 capslock灯不亮 原文链接:joselynzhao·CSDN·MacBook键盘锁定.按键失效.无反应等问题 MacBook按键无 ...

  5. Java 虚拟机垃圾收集机制详解

    本文摘自深入理解 Java 虚拟机第三版 垃圾收集发生的区域 之前我们介绍过 Java 内存运行时区域的各个部分,其中程序计数器.虚拟机栈.本地方法栈三个区域随线程共存亡.栈中的每一个栈帧分配多少内存 ...

  6. 部署 Prometheus 和 Grafana 到 k8s

    在 k8s 中部署 Prometheus 和 Grafana Intro 上次我们主要分享了 asp.net core 集成 prometheus,以及简单的 prometheus 使用,在实际在 k ...

  7. 第4章 基础知识进阶 第4.1节 Python基础概念之迭代、可迭代对象、迭代器

    第四章 基础知识进阶第十七节 迭代.可迭代对象.迭代器 一.    引言 本来计划讲完元组和字典后就讲列表解析和字典解析,但要理解列表解析和字典解析,就需要掌握Python的高级的类型迭代器,因此本节 ...

  8. 转:浅谈HTTP中Get、Post、Put与Delete的区别

    1.GET请求会向数据库发索取数据的请求,从而来获取信息,该请求就像数据库的select操作一样,只是用来查询一下数据,不会修改.增加数据,不会影响资源的内容,即该请求不会产生副作用.无论进行多少次操 ...

  9. 团队作业6(A)-Alpha阶段项目复审

    Alpha阶段项目复审 复审团队: 莫政 (3118005067). 卢耀恒(3118005065) . 许梓莹(3218005083). 梁小燕(3218005081).高嘉淳(3118005047 ...

  10. protobuf 协议浅析

    目录 Protobuf 协议浅析 1. Protobuf 介绍 1.1 Protobuf 基本概念 1.2 Protobuf 的优点 1.3 Protobuf, JSON, XML 的区别 2. Pr ...