序列化与反序列化
-
特点:
-
需要序列化的文件必须实现Serializable接口,用来启用序列化功能
如果本类的对象 想要被序列化输出 那么本类必须实现可序列化接口 否则会报错
报错信息:java.io.Not SerializableException:cn.tedu.seri.Student
Serializable 接口是一个空接口 里面一个方法也没有 作用是当做标志 标志这个类可以被序列化
-
不需要序列化的数据可以修饰成static,原因:static资源属于类资源,不随着对象被序列化输出
-
每一个被序列化的文件都有一个唯一的id,如果没有添加此id,编译器会自动根据类的定义信息计算产生一个
-
在反序列化时,如果和序列化的版本号不一致,无法完成反序列化
-
常用与服务器之间的数据传输,序列化成文件,反序列化读取数据
-
常用使用套接字流在主机之间传递对象
-
不需要序列化的数据也可以被修饰成transient(临时的),只在程序运行期间在内存中存在,不会被序列化持久保存
-
序列化:ObjectOutputStream
-
ObjectOutputStream 将 Java 对象的基本数据类型写入 OutputStream,通过在流中使用文件可以实现对象的持久存储。如果流是网络套接字流,则可以在另一台主机上或另一个进程中重构对象。 构造方法: ObjectOutputStream(OutputStream out) 创建写入指定 OutputStream 的 ObjectOutputStream 普通方法: writeObject(Object obj) 将指定的对象写入 ObjectOutputStream
反序列化:ObjectInputStream
-
ObjectInputStream对以前使用ObjectOutputStream写入的基本数据和对象进行反序列化重构对象。 构造方法: ObjectInputStream(InputStream in) 创建从指定 InputStream 读取的 ObjectInputStream 普通方法: readObject() 从 ObjectInputStream 读取对象