1、对象序列化
对象序列化就是将一个Java 对象转换为二进制的数据流,如果一个对象想要实现序列化,则该对象所在的此必须实现 Serializable 接口。此接口中没有任何方法,此接口只是一个标识,表示本类的对象具有了序列化的功能。
2、 如果对象想完成序列化功能,则依靠ObjectOutputStream 类和 ObjectInputStream 类,前者实现序列化操作,后者实现反序列化操作。
3、 创建Person 类
package com.chenzehe.test.serial; import java.io.Serializable; public class Person implements Serializable { private String name ; private int age ; public Person(String name, int age) { this . name = name; this . age = age; } public String toString() { return "姓名:" + this . name + ",年龄:" + this . age ; } }
4、 创建序列化测试类
package com.chenzehe.test.serial; import java.io.File; import java.io.FileOutputStream; import java.io.ObjectOutputStream; import com.chenzehe.test.serial.Person; public class ObjectOutputStreamTest { public static void main(String[] args) throws Exception { File file = new File( "D:" + File. separator + "person.ser" ); ObjectOutputStream objectOutputStream = new ObjectOutputStream( new FileOutputStream(file)); Person person = new Person( "chenzehe" , 100); objectOutputStream.writeObject(person); objectOutputStream.close(); } }
运行该代码,把person 对象的信息写到 person.ser 文件中,内容为二进制格式。
5、 反序列化
反序列化就是把序列化后的二进制文件转化成Java 对象
6、 创建实现反序列化测试类
package com.chenzehe.test.serial; import java.io.File; import java.io.FileInputStream; import java.io.ObjectInputStream; import com.chenzehe.test.serial.Person; public class ObjectIntputStreamTest { public static void main(String[] args) throws Exception { File file = new File( "D:" + File. separator + "person.ser" ); ObjectInputStream objectInputStream = new ObjectInputStream( new FileInputStream(file)); Person person = (Person) objectInputStream.readObject(); System. out .println( person ); } }
运行该类输出上面序列化的对象信息: 姓名:chenzehe,年龄:100
7、 如果类中某个属性不希望被序列化,则以transient 关键字声明,如把上面 Person 类中属性加上该关键字声明:
private transient String name ;
private transient int age ;
运行序列化测试类,然后运行反序列化操作,输出: 姓名:null,年龄:0 ,说明 Person类中的 name 属性和 age 属性没有被序列化。
8、 如果要对多个对象序列化,则可以使用数组,如下:
package com.chenzehe.test.serial; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.ObjectInputStream; import java.io.ObjectOutputStream; import com.chenzehe.test.serial.Person; public class Test { public static void main(String[] args) throws Exception { Person[] persons = { new Person( "chenzehe1" , 1), new Person( "chenzehe2" , 2), new Person( "chenzehe3" , 3) }; ser (persons); Person[] dpersons = (Person[]) dser (); println (dpersons); } public static void ser(Object object) throws Exception { File file = new File( "D:" + File. separator + "person.ser" ); ObjectOutputStream objectOutputStream = new ObjectOutputStream( new FileOutputStream(file)); objectOutputStream.writeObject(object); objectOutputStream.close(); } public static Object dser() throws Exception { File file = new File( "D:" + File. separator + "person.ser" ); ObjectInputStream objectInputStream = new ObjectInputStream ( new FileInputStream (file)); Person[] persons = (Person[]) objectInputStream. readObject (); return persons; } public static void println(Person[] persons) { for (Person p : persons) { System. out .println(p); } } } 上面输出所有对象的信息: 姓名:chenzehe1,年龄:1 姓名:chenzehe2,年龄:2 姓名:chenzehe3,年龄:3上面数据也可以改成集合来实现。
9、serialVersionUID
修改上面的Person类,添加一个属性:
private String sex;然后再把上面生成的person.ser文件进行反序列化,则会抛出异常:
java.io.InvalidClassException: com.chenzehe.test.serial.Person; local class incompatible: stream classdesc serialVersionUID = 1521932324078567475, local class serialVersionUID = 7186807995243487452在类中添加serialVersionUID属性:
private static final long serialVersionUID = 1521932324078567475L;当你一个类实现了Serializable接口,如果没有定义serialVersionUID,Eclipse会提供这个提示功能告诉你去定义 。在Eclipse中点击类中warning的图标一下,Eclipse就会自动给定两种生成的方式。有两种生成方式:
一个是默认的1L,比如:private static final long serialVersionUID = 1L;
一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,比如:
private static final long serialVersionUID = xxxxL;
此时把上面新增的属性sex去掉,进行序列化,再修改类的定义,增加sex属性,然后再进行反序列化就不出抛出上面的异常。
兼容也就是版本控制,java通过一个名为UID(stream unique identifier)来控制,这个UID是隐式的,它通过类名,方法名等诸多因素经过计算而得,理论上是一一映射的关系,也就是唯一的。如果UID不一 样的话,就无法实现反序列化了,并且将会得到InvalidClassException。
保持向上兼容性:
向上兼容性是指老的版本能够读取新的版本序列化的数据流。常常出现在我们的服务器的数据更新了,仍然希望老的客户端能够支持反序列化新的数据流,直到其更新到新的版本。可以说,这是半自动的事情,对于向下兼容性而言,旧的数据流中所包含的所有内容都将会被恢复,新版本的类中没有涉及到的部分将保持默认值。利用这一特性,可以说,只要我们认为的保持serialVersionUID不变,向上兼容性是自动实现的。 当然,一但我们将新版本中的老的内容拿掉,情况就不同了,即使UID保持不变,会引发异常。正是因为这一点,我们要牢记一个类一旦实现了序列化又要保持向上下兼容性,就不可以随随便便的修改了。
保持向下兼容性:
保持向下的兼容性至少有三点要求:
1.serialVersionUID保持一致
2.预先安插好我们自己的版本识别标志的final long ver=xxxx;
3.保证初始化所有的域
相关推荐
Java对象序列化是一种将Java对象转换为字节流的过程,以便可以存储在磁盘上、在网络上传输或在任何其他需要持久化数据的场景中使用。这个过程涉及到两个主要概念:序列化(Marshalling)和反序列化(Unmarshalling)...
Xson是一个Java对象序列化和反序列化程序。支持Java对象到字节数组的序列化,和从字节数组到Java对象的反序列化。 Maven: <groupId>com.github.xsonorg</groupId> <artifactId>xson-core <version>1.0.1 ...
Java对象序列化是Java平台的一项重要特性,它允许将对象的状态转换为字节流,以便存储、传输或恢复。在本文中,我们将深入探讨关于Java对象序列化你可能不知道的五件事情,这些知识点对于理解和优化你的Java应用程序...
### Java对象序列化标准知识点详解 #### 一、系统架构概览 **1.1 概览** Java 对象序列化是一种将Java对象的状态转换成字节流的过程,以便于在网络上传输或存储到磁盘上。Java序列化标准定义了一套规则来描述如何...
【JAVA对象序列化保存为XML文件的工具类】 在Java编程中,对象序列化是一种将对象的状态转换为字节流的过程,以便可以存储或在网络上传输。而在反序列化时,这个字节流又可以恢复为原来的对象。Java提供了一个方便...
Java对象序列化与反序列化是Java编程中重要的概念,主要应用于数据持久化、网络传输以及存储等场景。本文将详细解析这两个概念及其在实际应用中的实现方式。 **一、Java对象序列化** 1. **定义**: Java对象序列化...
Java对象序列化是一种将对象转换为字节流的过程,以便可以将其存储在磁盘上,或者在网络中进行传输。这是Java平台提供的一种功能,允许程序员将任何Java对象持久化,即将其状态保存到磁盘,或者在网络中进行传输。...
Java对象序列化是Java平台提供的一种机制,允许将对象的状态转换为字节流,以便存储在磁盘上、通过网络传输或在不同时间点恢复。这个过程涉及到将一个复杂的Java对象模型转换为简单的二进制表示,使得数据可以在不同...
Java对象序列化是一种将Java对象转换为字节流的过程,以便可以存储这些对象或通过网络进行传输。这个过程是Java平台的核心特性,它允许开发者将复杂的对象结构持久化或者在网络间进行安全通信。序列化不仅可以用于...
序列化的过程就是对象写入字节流和从字节流中读取对象。...对象序列化功能非常简单、强大,在RMI、Socket、JMS、EJB都有应用。对象序列化问题在网络编程中并不是最激动人心的课题,但却相当重要,具有许多实用意义。
Java对象序列化是Java开发中的一个重要概念,它允许我们将Java对象转换为字节流,以便存储、传输或在不同时间点恢复。以下是五个可能不为人知的关于Java对象序列化的知识点,这些知识点对于深入理解Java开发至关重要...
Java对象序列化是一种将Java对象转换为字节流的过程,以便于存储、传输或在网络间进行通信。这一过程使得对象的状态能够被持久化,即使在程序关闭后也能重新恢复。在Java中,对象序列化是通过实现`java.io....
总的来说,Java对象序列化是一个强大的工具,但也需要根据具体的应用场景进行适当的优化。开发者需要平衡性能需求、代码的可读性和维护性,以实现最佳的序列化策略。在考虑优化时,应始终注意性能测试,确保所做的...
本文介绍了Java对象序列化的五种方式,并提供了选择最适合应用程序的数据格式和技术所需要的全部信息。这篇文章侧重于可以用来生成 Java对象以数据为中心的视图的技术。演示可以把 JavaBeans变成XML文档的各种方法,...
Java对象序列化是一种将Java对象转换为字节流的过程,以便可以存储或在网络上传输。这一过程至关重要,因为它允许我们持久化对象的状态,以便在稍后的时间点恢复这些对象。在Java中,对象序列化主要涉及到`...
android(包括java)序列化一个对象传给php去做处理,或是接到php...//将一个对象序列化后返回byte[] String phpserialstr=new String(b); 将变量phpserialstr传给php即可. PHPSerializer中还有unserialize方法,是反序列化
这就是Java对象序列化与反序列化的基本概念,以及如何与JSON格式结合使用的示例。在实际应用中,我们还需要考虑异常处理、性能优化以及安全性问题,比如使用`transient`关键字忽略某些字段,或者使用`@...