介绍Java对象序列化使用基础

介绍Java对象序列化使用基础在我们平日开发中 经常让 PO 类去实现 Serializable 接口 然后让其可序列化 不过有时我们并不是特别清楚为什么要序列化 特别是对于纯 Web 项目开发的同学来说 需求环境不一定能用上 下面我简单和大家分享下自己对序列化的认知 一 什么是序列化 序列化 就是把 Java 对象转换成字节序列的过程 反之

大家好,我是讯享网,很高兴认识大家。



在我们平日开发中,经常让PO类去实现Serializable接口,然后让其可序列化。不过有时我们并不是特别清楚为什么要序列化,特别是对于纯Web项目开发的同学来说,需求环境不一定能用上。下面我简单和大家分享下自己对序列化的认知。

一、什么是序列化

序列化就是把Java对象转换成字节序列的过程。反之,把字节序列恢复成Java对象的过程就叫反序列化

二、为什么要序列化

在网络通信的过程中,我们的数据是需要变成字节序列才能在网络上进行传输。对于消息发送方来说,需要把Java对象转成字节序列才能发送;对于消息接收方来说,则需要把字节序列转成Java对象方能在内存中使用。

另一个场景就是需要把对象数据保存到硬盘,也就是做持久化。因为Java对象是在JVM中生成,属于内存数据,那么要保存到硬盘,则需要把它转换成二进制流(字节序列),也就是序列化。

三、怎样实现序列化

1、实现Serializable或者Externalizable这两个接口当中之一

在Java环境下,需要序列化的类,必须实现Serializable或者Externalizable这两个接口当中之一。Externalizable是继承Serializable,在jdk1.3之前,因Serializable是完全递归的算法导致效率低下,因此Externalizable是一个很好的替换方案。

不过随着jdk版本的性能不断优化,Serializable的性能问题已经得到妥善的解决。现在大多数开发人员都是使用Serializable。

Externalizable反而因其使用操作较为繁琐(需要无参构造方法、重载writeExternal和readExternal实现),而不被广泛使用。

 
讯享网 

2、序列化

Java中,我们使用ObjectOutputStream这个类进行序列化。通过把需要序列化的对象作为参数,传给writeObject方法。补偿一点的是ObjectOutputStream代表着对象输出流,它可以把对象写入到目标输出流里面。

讯享网

3、反序列化

与序列化ObjectOutputStream类相对应的,ObjectInputStream用于反序列化。我们可以调用它的readObject方法来读取字节序列,然后把该序列反序列化成对象。

 

4、运行结果

a、生成boy.txti

b.反序列化并打印相关信息:

讯享网

四、注意点:

1、被transient关键字和修饰的属性将不会被序列化

并不是对象所有属性我们都想进行序列化的,比如账号的密码。对于这种情况我们可以用transient来修饰,那么这个字段就不会被序列化。

介绍Java对象序列化使用基础

运行结果:

 

2、反序列化过程中,被没有调用对象的构造方法。

在发序列化过程中,被没有调用包括无参构造方法在内的所有构造器。这点从运行结果看出没有执行无参构造方法。

序列化的目的之一就是记录对象当时的状态,而构造方法有可能会对这个状态产生影响,因此反序列化时会调用native方法去处理。

小讯
上一篇 2025-01-02 23:38
下一篇 2024-12-26 21:54

相关推荐

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请联系我们,一经查实,本站将立刻删除。
如需转载请保留出处:https://51itzy.com/kjqy/7097.html