@Transient与序列化的理解

一、序列化

Serialization(序列化)是一种将对象以一连串的字节描述的过程,其实就是持久化;反序列化deserialization是一种将这些字节重建成一个对象的过程。将程序中的对象,放入文件中保存就是序列化,将文件中的字节码重新转成对象就是反序列化。

实际的开发场景1:

当银行有一个用户信息实体类UserInfo,那么在保存用户信息时,就需要先将用户信息对象UserInfo进行序列化;写到持久层数据库中;或者是在网络中调用传递对象;

public class CustomEvent implements Serializable{

    private static final long serialVersionUID = 6271319850724239564L

    private Integer parentId;//父事件ID
    private String idCord;//事件代码
    private String eventDesc;//事件描述
    private Integer eventCount;//将要去做的事件数量
    private String eventStart;
    private String eventEnd;
    private String cipher;//密码
}

开发场景2:

如果一个网站并发量,有很多用户对话,每次对话都有一个session对象,那么如果其中有对象一段时间离开,我们为了节省内存资源,就可以将当前的session对象序列化持久到磁盘中,当在一定时间内,用户再次启动对话,我们就可以马上反序列化出session,回到之前的状态下;

其他场景

当两个进程进行远程通信时,可以相互发送各种类型的数据,包括文本、图片、音频、视频等, 而这些数据都会以二进制序列的形式在网络上传送。

java是面向对象的开发方式,一切都是java对象,想要实现java对象的网络传输,就可以使用序列化和反序列化来实现。发送方将需要发送的Java对象序列化转换为字节序列,然后在网络上传送;接收方接收到字符序列后,使用反序列化从字节序列中恢复出Java对象。

序列化的作用:

一是实现了数据的持久化,通过序列化可以把数据永久地保存到硬盘上(通常存放在文件里);

二是利用序列化实现远程通信,即在网络上传送对象的字节序列。

总结,在网络中数据的传输必须是序列化形式来进行的。序列化的方式可以是json传输,xml形式传输。

二、@Transient出现

特殊场景:

当我对象UserInfo中有密码、银行账户等敏感信息时,我不能将对象的这些信息进行持久化;只想在内存中使用;那就必须对不想要进行持久化的部分进行标注;或者说数据库内没有的字段进行标注;

 javax.persistence.Transient;

public class CustomEvent implements Serializable{

    private static final long serialVersionUID = 6271319850724239564L

    private Integer parentId;//父事件ID
    @Transient
    private String idCord;
    private String eventDesc;//事件描述
    private Integer eventCount;//将要去做的事件数量
    private String eventStart;
    private String eventEnd;
    @Transient
    private String cipher;//密码
}

使用注解@Transient在不需要序列化的属性上标注出来;那么此时被标注的字段就只会存在调用者的内存中,而不会写在磁盘中,持久化;

三、serialVersionUID 作用

serialVersionUID用来区分不同版本的实体类

Java的序列化是通过运行时的判断实体类的serialVersionUID确定版本的一致性的;在反序列化时,JVM会把传过来的字节流的serialVersionUID与目前内存走实体类的serialVersionUID进行比较,如果相同,是一个版本,就会反序列化生成对象;否则出现序列化版本不一致异常;

当我们没有在类中定义名字为serialVersionUID,类型为long的静态变量时,实现java.io.Serializable接口的实体(类),在编译时;Java序列化机制会根据class自动的生成serialVersionUID用作版本区分;那么此时,则只有在同一次编译生成的class文件才会有相同的serialVersionUID;

所以我们如果不想通过编译来区分版本;即实现系列化的接口能够兼容先前版本的未作更改的类;就要定义serialVersionUID来实现,以及实现相同的serialVersionUID实体类进行反串行化和串行化;

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值