对象序列化的目标是将对象保存在磁盘中,或者是在网络中可以传输对象
1、对象序列化(输出)
就是将内存上的Java对象转换成与平台无关的二进制流,可以将这种二进制流持久的保存在磁盘上,或者是可以在网络上传输
-
实现
实现接口
Serializable
或者Externalizable
,该接口仅仅是标识一下可序列化,无需实现任何方法
2、对象序列化示例
将一个Java对象序列化成二进制流,输出到 test.txt 文件里面
public class WriteObject{
public static void main(Stirng[] args) throws IOException{
// 创建一个对象输出流
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("test.txt"));
// new 一个对象
Car car = new Car("红旗汽车");
oos.writeObject(car);
}
}
3、对象反序列化(输入)
- 反序列化只读取Java对象的数据,不是Java类,在进行反序列化的时候,必须提供Java对象所属类的文件
- 如果向文件序列化多个对象时,反序列化恢复时,也需要按照写入的顺序
- 当对象时引用类型,进行反序列化时,这个引用的类也需要是能可序列化的,而且,该类如果有父类,为了反序列化时能正常恢复,该父类也会被序列化
注意:当引用类父子类关系重复时,也只会序列化一次,根据序列化编号区分(当类变化时,序列化编号也不会变)
4、反序列化示例
从上面生成的 test.txt 文件中,读取 Car 对象
public class ReadObject{
public static void main(Stirng[] args) throws IOException{
// 创建一个对象输出流
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("test.txt"));
// 读取Car对象,知道类型,强转
Car c = (Car)ois.readObject();
}
}
5、Transient 关键字阻止变量被序列化
- 在变量声明前加
Transient
关键字,可以阻止该变量被序列化到文件中,在反序列化时,Transient 变量的值被设为默认初始值(如int 的0,引用对象的null) - 例如传输密码等敏感数据时