什么是序列化和反序列化:
序列化就是对一个Java做一下“变化”,变成字节序列。
方便持久化存储到磁盘,避免程序运行后对象就从内存里消失,另外变换成字节序列也更便于网络运输和传播。
序列化:把Java对象转换为字节序列。
反序列化:把字节序列恢复成原来的Java对象。

那么对象如何序列化?
Serializable接口或Externalizable接口
实现Serializable接口:
1) 系统自动存储必要的信息;
2) Java内建支持,易于实现,只需要实现接口,不需要任何代码支持;
3) 性能略差;实现Externalizable接口:
1) 自己决定要序列化哪些属性;
2) 必须实现该接口内的两个方法:
void writeExternal(ObjectOutput out) throws IOException;
void readExternal(ObjectInput in) throws IOException, ClassNotFoundException;
3) 性能略好;
1)使用transient关键字指定不进行序列化的字段。
使用transient修饰的属性,java序列化时会忽略该属性。而当反序列化时,被transient修饰的属性则赋予默认值。对于引用类型则为null,boolean类型为false,基本类型为0。
writeReplace()方法:在序列化前,会先调用该方法,再调用writeObject方法。此方法可以使用任意对象代替目标序列化对象。
博客介绍了Java中序列化和反序列化的概念。序列化是将Java对象转换为字节序列,便于持久化存储和网络传输;反序列化则是将字节序列恢复为Java对象。还阐述了对象序列化的方式,如实现Serializable或Externalizable接口,并对比了两者特点。

825

被折叠的 条评论
为什么被折叠?



