前段时间笔试碰到了一个这样的问题,Java类的序列化顺序,之前从来没有见过;
查阅一些资料后,自我感觉最好的回答就是它的代码了。(有更好的评论告诉我)
使用序列化的原因:Java对象在JVM运行时被创建、更新和销毁,当JVM退出时,对象也会随之销毁,即这些对象的生命周期不会比JVM的生命周期更长。但在现实应用中,我们常常需要将对象及其状态在多个应用之间传递、共享,或者将对象及其状态持久化,在其他地方重新读取被保存的对象及其状态继续进行处理。这就需要通过将Java对象序列化来实现。
对象序列化除了用于持久化对象,在RPC(远程过程调用)中,比如使用Dubbo进行远程调用对象Model时也需要将对象序列化implements Serializable。
一、 序列化顺序
1)创建一个ObjectOutputStream输出流;
2)调用对象的writeObject()方法将Student对象的状态信息写入磁盘中,在需要使用的时候再以文件流的方式将其读取并反序列化。
1、创建对象:
package pang.daily;
import java.io.Serializable;
public class Student implements Serializable {
private Integer id;
private String name;
private int age;
public Student(Integer id, String name, int age) {
this.id = id;
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "Student{" +
"StudentID=" + id +
", name='" + name + '\'' +
", age=" + age +
'}';
}
}
2、将对象序列化到文件持久化:
package pang.daily;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectOutputStream;
public class WriteObject {
public static void main(String[] args){
try {
FileOutputStream fileOutputStream = new FileOutputStream("student.txt");
ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream);
Student student = new Student(2222, "SmallPang", 22);
objectOutputStream.writeObject(student);
objectOutputStream.flush();
} catch (IOException e) {
e.printStackTrace();
}
}
}
二、反序列化顺序
1)创建一个ObjectInputStream输入流;
2)调用对象的readObject()方法,将磁盘数据解析成我们需要的对象及其状态数据。
3、读取文件并反序列化:
package pang.daily;
import java.io.FileInputStream;
import java.io.ObjectInputStream;
public class ReadObject {
public static void main(String[] args) {
try {
FileInputStream fileInputStream = new FileInputStream("student.txt");
ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream);
Student student = (Student) objectInputStream.readObject();
System.out.println(student);
} catch (Exception e) {
e.printStackTrace();
}
}
}