java 中对象的序列化是指:将对象转化为以字节序列的形式表示,一个序列化后的对象,可以被写入到数据库或者文件中,也可以
用于网络传输,一般当我们调用rpc(网络传输)的时候,经常需要我们的对象实现Serializable接口,序列化的最终目的是反序列化,反
序列化后的字节序列可以恢复成Java对象,这个过程叫反序列化。
# 序列化需要实现Serializable接口
class Person implements Serializable{
//该字段不被序列化
private transient String name;
private int age;
public Person(String name, int age){
this.name = name;
this.age = age;
}
@Override
public String toString(){
return this.name + "," + this.age;
}
}
public static void main(String[] args) {
/**
* 序列化和反序列化
*/
try {
ObjectOutputStream objectOutputStream = new ObjectOutputStream(new FileOutputStream("E:\\Serializable.txt"));
Person person = new Person("aa", 1);
objectOutputStream.writeObject(person);
ObjectInputStream objectInputStream = new ObjectInputStream(new FileInputStream("E:\\Serializable.txt"));
Person emp = (Person) objectInputStream.readObject();
System.out.println("person:" + emp.toString());
} catch (IOException | ClassNotFoundException e) {
e.printStackTrace();
}
}
//打印结果:person:null,1
//serialVersionUID 自己不写,默认会有一个,
1-serialVersionUID是序列化ID,序列化是通过判断类的serialVersionUID来验证版本一致的。
在进行反序列化时,jvm会把传来的字节流中的serialVersionUID与本地对应实体类中的serialVersionUID
对比,如果一致,可以进行反序列化,否则会报InvalidCastException