概念
在程序中所有的数据都是以流的方式进行传输或保存的,程序需要数据的时候要使用输入流读取数据,而当程序需要将一些数据保存起来的时候,就要使用输出流完成。程序中的输入输出都是以流的形式保存的,流中保存的实际上全都是字节文件。
I:
Input 输入流,从硬盘上面读取数据到内存里面,这叫输入
应用场景:磁盘上有一个1.TXT文件,可以将1.txt文件中的内容 读取到java代码中
O:
output 输出流, 从内存中写入到硬盘上面,这叫输出
应用场景:java 代码有一个String类型的数据,将整个String发类型的数据写入到磁盘某一个文件中2.txt
输入流:
分为两种情况:一种是字节输入流和字符输入流
输出流:
分为两种情况:一种是字节输出流和字符输出流
字节流与字符流
在java.io包中操作文件内容的主要有两大类:字节流、字符流,两类都分为输入和输出操作。在字节流中输出数据主要是使用OutputStream完成,输入使的是InputStream,在字符流中输出主要是使用Writer类完成,输入流主要使用Reader类完成。(这四个都是抽象类)。
java中提供了专用于输入输出功能的包Java.io,其中包括: InputStream,OutputStream,Reader,Writer。
InputStream 和OutputStream,两个是为字节流设计的,主要用来处理字节或二进制对象。Reader和 Writer.两个是为字符流(一个字符占两个字节)设计的,主要用来处理字符或字符串。字符流处理的单元为2个字节的Unicode字符,分别操作字符、字符数组或字符串,而字节流处理单元为1个字节,操作字节和字节数组。所以字符流是由Java虚拟机将字节转化为2个字节的Unicode字符为单位的字符而成的,所以它对多国语言支持性比较好!如果是音频文件、图片、歌曲,就用字节流好点,如果是关系到中文(文本)的,用字符流好点。所有文件的储存是都是字节(byte)的储存,在磁盘上保留的并不是文件的字符而是先把字符编码成字节,再储存这些字节到磁盘。在读取文件(特别是文本文件)时,也是一个字节一个字节地读取以形成字节序列。字节流可用于任何类型的对象,包括二进制对象,而字符流只能处理字符或者字符串; 2. 字节流提供了处理任何类型的IO操作的功能,但它不能直接处理Unicode字符,而字符流就可以。字节流是最基本的,所有的InputStrem和OutputStream的子类都是,主要用在处理二进制数据,它是按字节来处理的 但实际中很多的数据是文本,又提出了字符流的概念,它是按虚拟机的encode来处理,也就是要进行字符集的转化 这两个之间通过 InputStreamReader,OutputStreamWriter来关联,实际上是通过byte[]和String来关联 在实际开发中出现的汉字问题实际上都是在字符流和字节流之间转化不统一而造成的
我们还可以看到:
Reader类的read()方法返回类型为 int :作为整数读取的字符(占两个字节共16位),范围
在0到65535之间(0x00-0xffff),如果已到达流的末尾,则返回﹣1 inputStream 的 read ()虽然也返回 int ,但由于此类是面向字节流的,一个字节占8个位,所以返回0到255范围内的 int 字节值。如果因为已经到达流末尾而没有可用的字节,则返回值﹣1。因此对于不能用0-255来表示的值就得用字符流来读取!比如说汉字.
操作流程
在 Java 中操作也是有相应步骤的,以文件操作为例,主要的操作流程如下:
1使用 File 类打开一个文件
2通过字节流或字符流的子类,指定输出的位置
3进行读/写操作
4关闭输入/输出
IO 操作属于资源操作,一定要记得关闭
字节流和字符流使用是非常相似的,那么除了操作代码的不同之外,还有哪些不同呢?
字节流在操作的时候本身是不会用到缓冲区(内存)的,是与文件本身直接操作的,而字符流在操作的时候是使用到缓冲区的。字节流在操作文件时,即使不关闭资源(close方法),文件也能输出,但是如果字符流不使用close方法的话,则不会输出任何内容,说明字符流用的是缓冲区,并且可以使用flush方法强制进行刷新缓冲区,这时才能在不close的情况下输出内容