在Java中,把一组有序的数据序列称为流。
在Java中流是使用统一的方式操作输入和输出的数据。
流就是一个对象。所在的包java.io.*,Java I/O系统负责处理程序的输入和输出,java.io包它对各种常见的输入流和输出流进行了抽象。
a)输入流:将数据读取到程序中就是输入流,reader
b)输出流:将程序中的数据写出到文件中就是输出流。writer
a)字节类:如果数据流中最小的数据单元是字节,那么称这种流为字节流;字节流处理单元为 1 个字节,可以操作字节和字节数组
b)字符类:如果数据流中最小的数据单元是字符,那么称这种流为字符流。字符流处理的单元为 2 个字节的 Unicode 字符,可以操作字符、字符数组或字符串Java内用Unicode 编码存储字符,字符流处理类负责将外部的其他编码的字符流和java内Unicode 字符流之间的转换。字符流(一次可以处理一个缓冲区)一次操作比字节流(一次一个字节)效率高。
a)节点流,如FileInputStream
b)包装流/处理流,如BufferedInputStream。带有缓冲区
分别表示字节输入流和字节输出流,
是所有字节输入和输出流的父类.其中的方法参照下面的四
针对文件进行字节操作。
带有缓冲区的流。---调用flush()刷新缓冲流。
增强输入和输出流的性能。
提高读写的效率。
包装流是可以对其他流进行重新包装。
针对于基本数据类型进行操作
针对于类类型的数据(对象)进行操作。
序列化:将对象保存到文件中或者传输到网络的过程。 反序列化:将文件中或者网络中将对象读取到程序的过程。
进行序列化或者反序列化的类必须实现Serializable接口。该接口是一个空接口, 只是起到了标识的作用,标识该对象可以进行序列化和反序列化serialVersionUID用来表明实现序列化类的不同版本间的兼容性。如果你修改了此类, 要修改此值。否则以前用老版本的类序列化的类恢复时会出错。
transient:该修饰的属性不会被序列化。是透明的属性。
管道输入,输出流,
针对线程读取和写入数据
connect():管道输入流连接到管道输出流
是所有字符流输出和输入的父类。
字符流是在字节流的基础上进行字符编码(UTF-8,GBK,GB2312...)
一组转换流--->字节和字符之间的转换。
InputStreamReader:字节转换成字符的桥梁
OutputStreamWriter:字符转换成字节的桥梁
带有缓冲区的字符流。
1)保存hello,您好时指定编码方式。
取数据时也指定编码方式。
2)采用这种方式完成文件的拷贝工作。
针对文件的字符流
都是输出流,可以进行格式化输出
PrintWriter:即可以包装字符类,也可以包装字节流。
PrintStream即可以输出字符,也可以输出字节
在文件的任意位置进行读和写的操作
seek(long),read(),writer();
当操作大文件的时候使用该类。
在java.io包中,java.io.InputStream表示字节输入流,java.io.OutputStream表示字节输出流,它们都是抽象类,不能被实例化。
a)int read(): 从输入流读取一个8位的字节,把它转换为0-255之间的整数,并返回这一整数。例如,如果读到的字节为9,则返回9,如果读到
的字节为-9,则返回247。如果遇到输入流的结尾,则返回-1;
b)int read(byte[] b): 从输入流读取若干个字节,把它们保存到参数b指定的字节数组中。返回的整数表示读取的字节数。如果遇到输入流的结尾,则返回-1;
c)int read(byte[] b, int off, int len): 从输入流读取若干个字节,把它们保存到参数b指定的字节数组中。 返回的整数表示读取的字节数。参数off指定在字节数组中开始保存数据的起始下标,参数len指定读取的字节数目。返回的整数表示实现读取的字节数。如果遇到输入流的结尾,则返回-1;以上第一个read方法从输入流读取一个字节,而其余两个read方法从输入流批量读取若干字节。在从文件或键盘读数据时,采用后面两个read方法可以减少进行物理读文件或键盘的次数,因此能提高I/O操作的效率。
1)选择合适的流
2)创建流对象
3)进行读写的操作
4)关闭资源
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。
原创声明:本文系作者授权腾讯云开发者社区发表,未经许可,不得转载。
如有侵权,请联系 cloudcommunity@tencent.com 删除。