当前位置:网站首页 > Java基础 > 正文

介绍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方法去处理。

版权声明


相关文章:

  • java基础关于排序的笔试题2024-10-14 20:50:05
  • java面试官说我基础不行2024-10-14 20:50:05
  • java开发一个基础平台系统2024-10-14 20:50:05
  • 58同城0基础java面试2024-10-14 20:50:05
  • java跳槽基础知识2024-10-14 20:50:05
  • java基础代码编写2024-10-14 20:50:05
  • java基础考试卷2024-10-14 20:50:05
  • 用java基础开发安卓2024-10-14 20:50:05
  • 智能算法需要java基础吗2024-10-14 20:50:05
  • 2017java面试基础题2024-10-14 20:50:05