对象流-ObjectInputStream和ObjectOutputStream
序列化和和反序列化示意图
程序向文件中保存 “数据的值” 和 “数据类型” 成为序列化;
反过来,文件中的数据( “数据的值” 和 “数据类型”)重新恢复到程序中就成为反序列化,这个在微服务领域中应用较为广泛.
Serializable(可序列化)接口下没有任何方法,通常用这个接口
ObjectInputStream类继承图
ObjectOutputStream类继承图
//演示ObjectOutputStream的使用,完成数据的序列化
public class ObjectOutputStream_{
public static void main(String[] args) throws Exception{
//序列化后,保存的文件格式,不是存文本,而是按照他的格式来保存
String filePath = "e:\data.dat";
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream(filePath));
//序列化数据到 e:data.dat
oos.writeInt(100); // int -> Integer(实现了 Serializable)
oos.writeBoolean(true); //boolean -> Boolean(实现了 Serializable)
oos.writeChar('a'); // char -> Character(实现了 Serializable)
oos.writeDouble(9.5); // double -> Double (实现了 Serializable)
oos.writeUTF("序列化演示");//String
//保存一个Dog对象
oos.writeObject(new Dog("旺财",10));
oos.close();
System.out.printn("数据保存完毕(序列化形式)");
}
}
如果需要序列化某个类的对象,实现Serializable
代码运行效果
演示ObjectInputStream的使用,代码如下
//演示ObjectInputStream的使用,完成数据的反序列化
public class ObjectInputStream_{
public static void main(String[] args) throws IOException{
//指定反序列化的文件
String filePath = "e:\data.dat";
ObjectInputStream ois = new ObjectInputStream(new FileInputStream(filePath));
//读取
//解读:
//1. 读取(反序列化)的顺序需要和你保存的数据(序列化)的顺序一致
//2. 否则会出现异常
System.out.println(ois.readInt());
System.out.println(ois.readBoolean());
System.out.println(ois.readChar());
System.out.println(ois.readDouble());
System.out.println(ois.readUTF());
//dog的编译类型是Object,dog的运行类型是 Dog
Object dog = ois.readObject();
System.out.println("运行类型" + dog.getClass());
System.out.println("dog信息" + dog); //底层 Object -> Dog
//这里是特别重要的细节
//1.如果我们希望调用Dog的方法,需要向下转型
//2. 需要我们将Dog类的定义,放在可以引用的位置
Dog dog2 = (Dog)dog;
System.out.println(dog2.getName());
//关闭流,关闭外层流即可,底层会关闭FileInputStream流
ois.close();
}
}
dog对象的属性读取如果遇到问题时,在Dog类中加一个属性:
private static final long serialVersionUID = 100;
把UID写死,因为如果不写死,每次序列化读到的这个版本号不一样.
代码运行结果
对象处理流细节
3.利用serialVersionUID 提升兼容性,如果说日后在Dog类中添加了新的属性,例如hobby,那么反序列化时仍然会识别到这个Dog类,默认Dog类升级.
4.static,transient(瞬时)修饰的没办法序列化
5.
如果Master这里没被序列化就会报错
6.序列化会被子类继承



