一、对象操作:
ObjectInputStream
构造方法:
继承关系:
继承于:OutputStream
主要方法:
Object readObject() 读取一个对象。 序列化操作的特有方法
ObjectOutputStream
构造方法:
ObjectOutputStream(OutputStream out) 传入的是节点流的实例
继承关系:
继承于 InputStream
主要方法:
void writeObject(Object obj) 写出一个对象。反序列化操作的特有方法
1、序列化、反序列化:
该对象类必须实现序列化接口。
序列化: 将对象转成为字节码的过程
反序列化: 将字节转化为对象,在反序列化时首先检查版本号。
注意点:
1、只有该对象类实现了序列化接口java.io.Serializable接口,该类的对象才能实现序列化
2、只能对引用类型进行操作
3、序列化版本号: serialVersionUID,每个对象的唯一标识, 反序列化前会先检查版本号。
版本号生成方式: 1、默认生成1L, 2、根据方法、属性等生成一个64位的哈希字段。
4、使用transient修饰的属性不被序列化或者反序列化
5、被static 修饰的静态变量不能被序列化(静态变量是类的属性,不属于对象属性。)
2、作用
1、对象储存到本地磁盘需要序列化
2、数据在网络中传输中,对敏感数据不进行