Java 序列化原理

我的网站 | 我的博客 | 序列化解析工具

概念

Java为我们提供了一种默认的对象序列化机制,通过这种机制可以将一个实例对象写入到IO流中,当然这种IO流可以是文件流、网络流或者其他什么流。

代码的写法

  • ObjectOutputStream 对象输出流,用于序列化一个对象
  • ObjectInputStream 对象输入流,用于反序列化一个对象
  • Serializable 和 Externalizable 只有实现其中一个接口的类的对象才能被序列化

注1:Externalizable 是序列化的一个扩展接口,它本身继承了Serializable接口。实现Externalizable接口的对象在序列化和反序列化时会用 writeExternal 和readExternal 方法替换默认的处理逻辑

注2: 反序列化时 serialVersionUID 的值必须和序列化时的一致,否则反序列报错失败

将对象序列化到文件流中

 String file = "string3.out";
 ObjectOutputStream outputStream = new ObjectOutputStream(new FileOutputStream(file));
 TestObject testObject = new TestObject();
 testObject.setContent("test");
 outputStream.writeObject(testObject);

从文件流中反序列化

String file = "string3.out";
ObjectInputStream in = new ObjectInputStream(new FileInputStream(file));
TestObject responseBean = (TestObject) in.readObject();
System.out.println(responseBean.getContent());

两种实现方式

1、实现 Serializable 接口
@Setter
@Getter
public class TestObject extends UnicodeRequest implements Serializable {
       private static final long serialVersionUID = 5347411908895007509L;
       private String content;
}
2、实现 Externalizable 接口
@Setter
@Getter
public class TestObject extends UnicodeRequest implements Externalizable {
     private static final long serialVersionUID = 5347411908895007509L;
     private String content;
       
    @Override
    public void writeExternal(ObjectOutput out) throws IOException {
        out.writeUTF(this.content);
    }

    @Override
    public void readExternal(ObjectInput in) throws IOException, ClassNotFoundException {
        this.conent = in.readUTF();
    }
}

五种特殊的方法

如果被序列化对象实现了以下5种特殊的方法,会影响序列化或反序列化时原有的行为。

以下1个特殊的方法 用于序列化和反序列化的对像替换,常用于单例对象的序列化,保证单例的绝对安全。

ANY-ACCESS-MODIFIER Object readResolve() throws ObjectStreamException;

ANY-ACCESS-MODIFIER Object writeReplace() throws ObjectStreamException;

以下3个特殊的方法 用于替换默认的序列化行为。

:如果对象实现了Externalizable接口,下边的方法就不在有作用了。

private void writeObject(java.io.ObjectOutputStream out) throws IOException;

private void readObject(java.io.ObjectInputStream in) throws IOException, ClassNotFoundException;

private void readObjectNoData() throws ObjectStreamException;

序列化原理

Type Code

type code说明
Bbyte
Cchar
Ddouble
Ffloat
Iint
Jlong
Lclass or interface
Sshort
Zboolean
[array

如果超类没有实现 Serializable 接口则不会被序列化

对于ObjectOutputStream 的一个实例来说相同的对象不会重复序列化

serialVersionUID 不一致 反序列化失败

serialVersionUID 一致情况下,字段的缺失或者添加 都不会影响 反序列化

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值