开胃菜
先看一张网上流传的http://java.io包的类结构图:
当你看到这幅图的时候,我相信,你跟我同样心里是崩溃的。java
有些人不怕枯燥,不怕寂寞,硬着头皮看源码,可是,能坚持下去所有看完的又有几个呢!面试
然而,就算源码所有看完看懂,过不了几天,脑子里也会变成一团浆糊。数组
由于这里的类实在太多了。可能咱们反复看,反复记,也很难作到清晰明白。微信
他就像是一块超级硬的骨头,怎么啃都啃不烂。dom
面对这样的作法,要坚定对他说,NO。函数
记不住,怎么办?
个人作法是找出他们的共性,给他们分类,只记典型,举一反三。工具
上面的图虽然有分类,可是还不够细,并且没有总结出方便记忆的规律,因此咱们要从新整理和归类。学习
这篇文章中,使用了两种分时给他们分组,目的是更全面的了解共性,帮助记忆。spa
分类一:按操做方式(类结构)
字节流和字符流:线程
- 字节流:以字节为单位,每次次读入或读出是8位数据。能够读任何类型数据。
- 字符流:以字符为单位,每次次读入或读出是16位数据。其只能读取字符类型数据。
输出流和输入流:
- 输出流:从内存读出到文件。只能进行写操做。
- 输入流:从文件读入到内存。只能进行读操做。
注意: 这里的出和入,都是相对于系统内存而言的。
节点流和处理流:
- 节点流:直接与数据源相连,读入或读出。
- 处理流:与节点流一块使用,在节点流的基础上,再套接一层,套接在节点流上的就是处理流。
为何要有处理流?直接使用节点流,读写不方便,为了更快的读写文件,才有了处理流。
按操做方式分类结构图:
根据以上分类,以及jdk的说明,咱们能够画出更详细的类结构图,以下:
分类说明:
1) 输入字节流InputStream:
- ByteArrayInputStream、StringBufferInputStream、FileInputStream 是三种基本的介质流,它们分别从Byte 数组、StringBuffer、和本地文件中读取数据。
- PipedInputStream 是从与其它线程共用的管道中读取数据。PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操做。主要用于线程操做。
- DataInputStream: 将基础数据类型读取出来
- ObjectInputStream 和全部 FilterInputStream 的子类都是装饰流(装饰器模式的主角)。
2)输出字节流OutputStream:
- ByteArrayOutputStream、FileOutputStream: 是两种基本的介质流,它们分别向- Byte 数组、和本地文件中写入数据。
- PipedOutputStream 是向与其它线程共用的管道中写入数据。
- DataOutputStream 将基础数据类型写入到文件中
- ObjectOutputStream 和全部 FilterOutputStream 的子类都是装饰流。
节流的输入和输出类结构图:
3)字符输入流Reader::
- FileReader、CharReader、StringReader 是三种基本的介质流,它们分在本地文件、Char 数组、String中读取数据。
- PipedReader:是从与其它线程共用的管道中读取数据
- BufferedReader :加缓冲功能,避免频繁读写硬盘
- InputStreamReader: 是一个链接字节流和字符流的桥梁,它将字节流转变为字符流。
4)字符输出流Writer:
- StringWriter:向String 中写入数据。
- CharArrayWriter:实现一个可用做字符输入流的字符缓冲区
- PipedWriter:是向与其它线程共用的管道中写入数据
- BufferedWriter : 增长缓冲功能,避免频繁读写硬盘。
- PrintWriter 和PrintStream 将对象的格式表示打印到文本输出流。 极其相似,功能和使用也很是类似
- OutputStreamWriter: 是OutputStream 到Writer 转换的桥梁,它的子类FileWriter 其实就是一个实现此功能的具体类(具体能够研究一SourceCode)。功能和使用和OutputStream 极其相似,后面会有它们的对应图。
字符流的输入和输出类结构图:
分类二:按操做对象
分类说明:
对文件进行操做(节点流):
- FileInputStream(字节输入流),
- FileOutputStream(字节输出流),
- FileReader(字符输入流),
- FileWriter(字符输出流)
对管道进行操做(节点流):
- PipedInputStream(字节输入流),
- PipedOutStream(字节输出流),
- PipedReader(字符输入流),
- PipedWriter(字符输出流)。
- PipedInputStream的一个实例要和PipedOutputStream的一个实例共同使用,共同完成管道的读取写入操做。主要用于线程操做。
字节/字符数组流(节点流):
- ByteArrayInputStream,
- ByteArrayOutputStream,
- CharArrayReader,
- CharArrayWriter;
除了上述三种是节点流,其余都是处理流,须要跟节点流配合使用。
Buffered缓冲流(处理流):
带缓冲区的处理流,缓冲区的做用的主要目的是:避免每次和硬盘打交道,提升数据访问的效率。
- BufferedInputStream,
- BufferedOutputStream,
- BufferedReader,
- BufferedWriter,
转化流(处理流):
- InputStreamReader:把字节转化成字符;
- OutputStreamWriter:把字节转化成字符。
基本类型数据流(处理流):用于操做基本数据类型值。
由于平时如果咱们输出一个8个字节的long类型或4个字节的float类型,那怎么办呢?能够一个字节一个字节输出,也能够把转换成字符串输出,可是这样转换费时间,如果直接输出该多好啊,所以这个数据流就解决了咱们输出数据类型的困难。数据流能够直接输出float类型或long类型,提升了数据读写的效率。
- DataInputStream,
- DataOutputStream。
打印流(处理流):
通常是打印到控制台,能够进行控制打印的地方。
- PrintStream,
- PrintWriter,
对象流(处理流):
把封装的对象直接输出,而不是一个个在转换成字符串再输出。
- ObjectInputStream,对象反序列化;
- ObjectOutputStream,对象序列化;
合并流(处理流):
- SequenceInputStream:能够认为是一个工具类,将两个或者多个输入流当成一个输入流依次读取。
其余类:File(已经被Java7的Path取代)
File类是对文件系统中文件以及文件夹进行封装的对象,能够经过对象的思想来操做文件和文件夹。 File类保存文件或目录的各类元数据信息,包括文件名、文件长度、最后修改时间、是否可读、获取当前文件的路径名,判断指定文件是否存在、得到当前目录中的文件列表,建立、删除文件和目录等方法。
其余类:RandomAccessFile
该对象并非流体系中的一员,其封装了字节流,同时还封装了一个缓冲区(字符数组),经过内部的指针来操做字符数组中的数据。 该对象特色:
- 该对象只能操做文件,因此构造函数接收两种类型的参数:a.字符串文件路径;b.File对象。
- 该对象既能够对文件进行读操做,也能进行写操做,在进行对象实例化时可指定操做模式(r,rw)。
注意: IO中的不少内容均可以使用NIO完成,这些知识点你们知道就好,使用的话仍是尽可能使用NIO/AIO。
欢迎关注个人微信公众号:”Java面试通关手册”(一个有温度的微信公众号,期待与你共同进步~~~坚持原创,分享美文,分享各类Java学习资源):