java基础系列(八)之自定义序列化

本文探讨了Java中的序列化和反序列化,强调自定义序列化的重要性。通过实现Serializable接口,可以实现对象的序列化,但静态和transient变量不受支持。序列化在远程通信和对象深拷贝中扮演关键角色。自定义序列化则需要实现Externalizable接口,并确保写入和读取字段的顺序一致。虽然Java内置序列化效率较低,但在大型项目中常采用如Hadoop的高效序列化机制,或使用Jackson、Gson等第三方库。对于复杂对象的序列化,这些库可能表现不佳,因此理解Java序列化接口仍具价值。
摘要由CSDN通过智能技术生成

我们都知道java中实现序列化和反序列化,一般只需要实现接口Serializable即可。
一.序列化,反序列化

1.定义:
序列化:将数据分解成字节流,以便存储在文件中或在网络上传输。
反序列化:打开字节流并重构对象。对象序列化不仅要将基本数据类型转换成字节表示,有时还要恢复数据。恢复数据要求有恢复数据的对象实例。

2.java中序列化特点:
如果某个类能够被序列化,其子类也可以被序列化。声明为statictransient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据。

3.应用场景:

1):远程通信
对象序列化可以进行远程通信,作为信息进行传递,实现分布式对象
主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样,这就是远程过程调用RPC
2):对象深拷贝
对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的”深复制”,即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列。

二.普通序列化过程
需要序列化的类直接实现Serializable接口即可,不需要序列化的字段前加上transient即可。一旦变量被transient修饰,变量将不再是对象持久化的一部分,该变量内容在序列化后无法获得访问

1.复杂pojo类
import java.io.Serializable;
import java.util.ArrayList;
import java.util.Map;
public class User implements Serializable{
   
private static final long serialVersionUID=1l;
public String username="";
public int id=0;
public ArrayList<Link>link=null;
public Map result=null;
// setter and getter省略
}
import java.io.Serial
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值