前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Java IO流知识点总结

Java IO流知识点总结

作者头像
全栈程序员站长
发布2022-08-31 11:01:24
2810
发布2022-08-31 11:01:24
举报

大家好,又见面了,我是你们的朋友全栈君。

Java IO流总结

最近对java IO流进行了比较全面的学习,下面对知识点进行比较全面的总结:

一.IO流的基本概念

IO流主要用于硬板、内存、键盘等处理设备上得数据操作,根据处理数据的数据类型的不同可以分为:

字节流(抽象基类为InPutStream和OutPutStream)和字符流(抽象基类为Reader和Writer)。

根据流向不同,可以分为:输入流和输出流。

字符流和字节流的主要区别:

1.字节流读取的时候,读到一个字节就返回一个字节;

字符流使用了字节流读到一个或多个字节(中文对应的字节数是两个,在UTF-8码表中是3个字节)时。

先去查指定的编码表,将查到的字符返回。

2.字节流可以处理所有类型数据,如:图片,MP3,AVI视频文件,而字符流只能处理字符数据。

只要是处理纯文本数据,就要优先考虑使用字符流,除此之外都用字节流。

二.IO流结构图表示:

(一)基类图

Java IO流知识点总结
Java IO流知识点总结

(二)字节流相关类图

Java IO流知识点总结
Java IO流知识点总结

(三)字符流相关类图

Java IO流知识点总结
Java IO流知识点总结

(四)IO流主要可以分为节点流和处理流两大类。

1.节点流类型

该类型可以从或者向一个特定的地点或者节点读写数据。

2.处理流类型

该类型是对一个已存在的流的连接和封装,通过所封装的流的功能调用实现数据读写,处理流的构造方法总是要带一个其他流对象作为参数,一个流对象进过其他流的多次包装,叫做流的链接。

3.IO流的详细分类

注:下表中带下划线的是抽象类,不能创建对象。粗体部分是节点流,其他就是常用的处理流。

流分类

使用分类

字节输入流

字节输出流

字符输入流

字符输出流

抽象基类

InputStream

OutputStream

Reader

Writer

节点流

访问文件

FileInputStream

FileOutStream

FileReader

FileWriter

访问数值

ByteArrayInputStream

ByteArrayOutStream

CharArrayReader

CharArrayWriter

访问管道

PipedInputStream

PipedOutStream

PipedReader

PipedWriter

访问字符串

StringReader

StringWriter

处理流

缓冲流

BufferedInputStream

BufferedOutputStream

BufferedReader

BufferedWriter

转换流

InputStreamReader

OutputStreamWriter

对象流

ObjectInputStream

ObjectOutputStream

抽象基类(过滤)

FilterInputStream

FilterOutputStream

FilterReader

FilterWriter

打印流

PrintStream

PrintWriter

推回输入流

PushbackInputStream

PushbackReader

特殊流

DataInputStream

DataOutputStream

对于上面罗列的所有类,不一定要全部掌握,

但是基本的输入和输出的类还是要很熟练掌握的,无论是字节流还是字符流。

4.对部分类的具体描述

(1)、缓冲流(BufferedInPutStream/BufferedOutPutStream和BufferedWriter/BufferedReader)

他可以提高对流的操作效率。

写入缓冲区对象:

BufferedWriter bufw=new BufferedWriter(new FileWriter(“buf.txt”));

读取缓冲区对象:

BufferedReader bufr=new BufferedReader(new FileReader(“buf.txt”));

该类型的流有一个特有的方法:readLine();一次读一行,到行标记时,

将行标记之前的字符数据作为字符串返回,当读到末尾时,返回null,

其原理还是与缓冲区关联的流对象的read方法,只不过每一次读取到一个字符,

先不进行具体操作,先进行临时储存,当读取到回车标记时,将临时容器中储存的数据一次性返回。

WriteLine()同理。

(2)、转换流(InputStreamReader/OutputStreamWriter)

该类型时字节流和字符流之间的桥梁,该流对象中可以对读取到的字节数据进行指定编码的编码转换。

构造函数主要有:

1. InputStreamReader(InputStream); //通过构造函数初始化,使用的是本系统默认的编码表GBK。

2. InputStreamWriter(InputStream,String charSet); //通过该构造函数初始化,可以指定编码表。

3. OutputStreamWriter(OutputStream); //通过该构造函数初始化,使用的是本系统默认的编码表GBK。

4. OutputStreamwriter(OutputStream,String charSet); //通过该构造函数初始化,可以指定编码表。

注意:在使用FileReader操作文本数据时,该对象使用的时默认的编码表,即

FileReader fr=new FileReader(“a.txt”);

与 InputStreamReader isr=new InputStreamReader(new FileInputStream(“a.txt”)); 的意义相同。

如果要使用指定表编码表时,必须使用转换流,

即如果a.txt中的文件中的字符数据是通过utf-8的形式编码,

那么在读取时,就必须指定编码表,那么转换流时必须的。即:

InputStreamReader isr=new InputStreamReader(new FileInputStream(“a.txt”),utf-8);

3、数据流(DataInputStream/DataOutputStream)

该数据流可以方便地对一些基本类型数据进行直接的存储和读取,

不需要再进一步进行转换,通常只要操作基本数据类型的数据,就需要通过DataStream进行包装。

构造方法:

1. DataInputStreamReader(InputStream);

2. DataInputStreamWriter(OutputStream);

方法举例:

1. int readInt();//一次读取四个字节,并将其转成int值

2. writeInt(int);//一次写入四个字节,注意和write(int)不同,write(int)只将该整数的最低一个8位写入,剩余三个8为丢失

3. hort readShort();

4. writeShort(short);

5. String readUTF();//按照utf-8修改版读取字符,注意,它只能读writeUTF()写入的字符数据。

6. writeUTF(String);//按照utf-8修改版将字符数据进行存储,只能通过readUTF读取。

注意:在使用数据流读/存数据的时候,需要有一定的顺序,即某个类型的数据先写入就必须先读出,服从先进先出的原则。

4、打印流(PrintStream/PrintWriter)

PrintStream是一个字节打印流,System.out对应的类型就是PrintStream,

它的构造函数可以接受三种数据类型的值:1.字符串路径。2.File对象 3.OutputStream

PrintStream是一个字符打印流,它的构造函数可以接受四种类型的值:1.字符串路径。2.File对象 3.OutputStream 4.Writer 对于1、2类型的数据,可以指定编码表,也就是字符集,对于3、4类型的数据,可以指定自动刷新,当该自动刷新为True时,只有3个方法可以用:println,printf,format。

5、对象流(ObjectInputStream/ObjectOutputStream)

该类型的流可以把类作为一个整体进行存取,主要方法有:

Object readObject();该方法抛出异常:ClassNotFountException。

void writeObject(Object):被写入的对象必须实现一个接口:Serializable,否则就会抛出:NotSerializableException

本文只是对java IO流知识点的概括性总结和应用,适合那些对IO理解比较全面的人看。

对于基础不强的同学,随意浏览一下就可以了。

本文实际操作的没有很详细的阐述,下面也会有比较详细描述操作的文章发表,主要针对初级开发者。

发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/143965.html原文链接:https://javaforall.cn

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2022年5月2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
容器服务
腾讯云容器服务(Tencent Kubernetes Engine, TKE)基于原生 kubernetes 提供以容器为核心的、高度可扩展的高性能容器管理服务,覆盖 Serverless、边缘计算、分布式云等多种业务部署场景,业内首创单个集群兼容多种计算节点的容器资源管理模式。同时产品作为云原生 Finops 领先布道者,主导开源项目Crane,全面助力客户实现资源优化、成本控制。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档