概念
* IO流失用来处理设备之间的数据传输
* java对数据的操作都是通过流的方式,操作流的类都放在IO包
* 分类
1.字节流:
操作任何数据,因为在计算机中任何数据都是以字节的形式存储的
* 抽象父类:InputStream(输入),OutputStream(输出)
* 子类:
(1)FileInputStream:从文件中获取输入字节。媒体文件
BufferedInputStream:带有缓冲区的字节输入流
(2)FileOutStream:文件输出流,将数据写入文件
BufferedOutputStream:带有缓冲区的字节输出流
PrintStream:打印流,作为输出打印
2.字符流:
只能操作纯字符数据,比较方便
* 抽象父类:Reader(输入),Writer(输出)
* 子类:
(1)FileReader:读取字符文件的便捷类。
BufferedReader:将字符存入缓冲区,再读取
InputStreamReader:转换流,字节流和字符流的桥梁,多在编码的地方使用
(2)FileWriter:写入字符文件的便捷类。
BufferedWriter:将字符存入缓冲区,再写入
OutputStreamWriter:转换流,字节流和字符流的桥梁,多在编码的地方使用
* 注:
(1)FileReader是使用默认码表读取文件, 如果需要使用指定码表读取,
那么可以使用InputStreamReader(字节流,编码表)
(2)FileWriter是使用默认码表写出文件, 如果需要使用指定码表写出,
那么可以使用OutputStreamWriter(字节流,编码表)
3.是否提高效率:用BufferedXXX
将流读/写到缓冲区,缓冲区在内存里,相较磁盘的读写效率高很多
方法
* int read():一次读取一个字节/字符数组
* write():一次写出一个字节/字符数组
* available()获取读的文件所有的字节个数
* close()关流释放资源的的,如果是带缓冲区的流对象的close()方法,
不但会关闭流,还会再关闭流之前刷新缓冲区,关闭后不能再写出
* flush()用来刷新缓冲区的,刷新后可以再次写出
常见问题
- (read()方法返回值为什么是int)
read()方法读取的是一个字节,为什么返回是int,而不是byte
因为字节输入流可以操作任意类型的文件,比如图片音频等,
这些文件底层都是以二进制形式的存储的,如果每次读取都返回byte,
有可能在读到中间的时候遇到111111111
那么这11111111是byte类型的-1,我们的程序是遇到-1就会停止不读了,
后面的数据就读不到了,所以在读取的时候用int类型接收,
如果11111111会在其前面补上24个0凑足4个字节,那么byte类型的-1就变成int类型的255了
这样可以保证整个数据读完,而结束标记的-1就是int类型