字符输出流
-
字符流的应用限制比较多,没有字节流的应用广。
主要有以下几点: -
字符流不使用close方法的话,文件则不会输出任何内容。
-
字符流主要是用于处理中文,很方便快捷,但是其他的就不行了,例如音频、图片、视频等。但是,字符流拷贝文本文件时非常的快!
缓冲流
-
缓冲流主要是为了提高整体的读取、写入效率,降低了CPU通过内存访问硬盘的次数。提高效率,降低磁盘损耗。
字节输入缓冲
BufferedInputStream
字节输出缓冲
BufferedOutputStream
字符输入缓冲
BufferedReader
字符输出缓冲
BufferedWrite
【重点】 -
所有的缓冲流都没有任何的读取,写入文件能力,这里都需要对应的输入流和输出流来提供对应的能力。
-
在创建缓冲流流对象时,需要传入对应的输入流对象和输出流对象。
-
底层就是提供了一个默认大小的缓冲数组,用于提高效率
其中,字节缓冲流的底层中有一个默认容量为8KB的byte类型缓冲数组。字符缓冲流的底层中有一个默认容量为16KB的byte类型缓冲数组。而(字符、字节)输入缓冲流中fill方法是一个操作核心
- 从硬盘中读取数据,读取的数据容量和缓冲数组容量一致。
- 所有的read方法,都是从缓冲数组中读取数据
- 每一次读取数据之前,都会检查缓冲区内是否有数据,如果没有,fill方法执行,填充数据。利用缓冲,fill方法,可以极大的降低CPU通过内存访问硬盘的次数。同时程序操作的数据是在内存中进行交互的。
示例代码
public static void saveData(StudentManager studentManager) {
BufferedWriter bw = null;
try {
// 选择写入文件的方式是删除写!!!
bw = new BufferedWriter(new FileWriter(new File("./data/students.txt")));
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} finally {
if (bw != null) {
try {
bw.close();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}
}
}
序列化
-
用途:
Java中提供了一种序列化操作的方式,用一个字节序列化来表示一个对象,该字节序列化中保存了【对象的属性】,【对象的类型】和【对象的数据】。把字节序列化保存到文件中,就可以做到持久化保存数据内容。 -
ObjectOutputStream类
将对象数据序列化,保存到文件中 -
ObjectInputStream类
从文件中读取被序列化之后的字节数据,提供反序列化操作,得到一个对象。
【序列化注意事项】 -
如果一个类需要进行序列化操作,必须遵从。java.io.Serializable。不遵从无法进行序列化操作
-
序列化之后从文件中读取序列化内容,转换成对应的对象,ClassNotFoundException 对应类没有找到。对应的类型没有导包,不存在…InvalidClassException 类型不一样序列化之后的每一个类都会有一个serialVersionUID,该编号在使用过程中,序列化和反序列化必须一致
-
transient 修饰的成员变量不能被序列化