`
chenzehe
  • 浏览: 539593 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

Java对象序列化

 
阅读更多

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对象序列化是一种将Java对象转换为字节流的过程,以便可以存储在磁盘上、在网络上传输或在任何其他需要持久化数据的场景中使用。这个过程涉及到两个主要概念:序列化(Marshalling)和反序列化(Unmarshalling)...

    Java对象序列化和反序列化工具Xson.zip

    Xson是一个Java对象序列化和反序列化程序。支持Java对象到字节数组的序列化,和从字节数组到Java对象的反序列化。 Maven:  <groupId>com.github.xsonorg</groupId>  <artifactId>xson-core  <version>1.0.1 ...

    关于 Java 对象序列化您不知道的 5 件事

    Java对象序列化是Java平台的一项重要特性,它允许将对象的状态转换为字节流,以便存储、传输或恢复。在本文中,我们将深入探讨关于Java对象序列化你可能不知道的五件事情,这些知识点对于理解和优化你的Java应用程序...

    Java对象序列化标准最新版

    ### Java对象序列化标准知识点详解 #### 一、系统架构概览 **1.1 概览** Java 对象序列化是一种将Java对象的状态转换成字节流的过程,以便于在网络上传输或存储到磁盘上。Java序列化标准定义了一套规则来描述如何...

    JAVA对象序列化保存为XML文件的工具类

    【JAVA对象序列化保存为XML文件的工具类】 在Java编程中,对象序列化是一种将对象的状态转换为字节流的过程,以便可以存储或在网络上传输。而在反序列化时,这个字节流又可以恢复为原来的对象。Java提供了一个方便...

    java对象序列化和反序列化

    Java对象序列化与反序列化是Java编程中重要的概念,主要应用于数据持久化、网络传输以及存储等场景。本文将详细解析这两个概念及其在实际应用中的实现方式。 **一、Java对象序列化** 1. **定义**: Java对象序列化...

    java对象序列化.ppt

    Java对象序列化是一种将对象转换为字节流的过程,以便可以将其存储在磁盘上,或者在网络中进行传输。这是Java平台提供的一种功能,允许程序员将任何Java对象持久化,即将其状态保存到磁盘,或者在网络中进行传输。...

    Java对象序列化的秘密

    Java对象序列化是Java平台提供的一种机制,允许将对象的状态转换为字节流,以便存储在磁盘上、通过网络传输或在不同时间点恢复。这个过程涉及到将一个复杂的Java对象模型转换为简单的二进制表示,使得数据可以在不同...

    java对象序列化 传输 保存

    Java对象序列化是一种将Java对象转换为字节流的过程,以便可以存储这些对象或通过网络进行传输。这个过程是Java平台的核心特性,它允许开发者将复杂的对象结构持久化或者在网络间进行安全通信。序列化不仅可以用于...

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

    序列化的过程就是对象写入字节流和从字节流中读取对象。...对象序列化功能非常简单、强大,在RMI、Socket、JMS、EJB都有应用。对象序列化问题在网络编程中并不是最激动人心的课题,但却相当重要,具有许多实用意义。

    关于Java对象序列化您不知道的5件事Java开发Java

    Java对象序列化是Java开发中的一个重要概念,它允许我们将Java对象转换为字节流,以便存储、传输或在不同时间点恢复。以下是五个可能不为人知的关于Java对象序列化的知识点,这些知识点对于深入理解Java开发至关重要...

    Java对象序列化详细解析.doc

    Java对象序列化是一种将Java对象转换为字节流的过程,以便于存储、传输或在网络间进行通信。这一过程使得对象的状态能够被持久化,即使在程序关闭后也能重新恢复。在Java中,对象序列化是通过实现`java.io....

    Java对象序列化.pdf

    总的来说,Java对象序列化是一个强大的工具,但也需要根据具体的应用场景进行适当的优化。开发者需要平衡性能需求、代码的可读性和维护性,以实现最佳的序列化策略。在考虑优化时,应始终注意性能测试,确保所做的...

    面向Java开发人员的Ajax之2:Ajax的Java对象序列化

    本文介绍了Java对象序列化的五种方式,并提供了选择最适合应用程序的数据格式和技术所需要的全部信息。这篇文章侧重于可以用来生成 Java对象以数据为中心的视图的技术。演示可以把 JavaBeans变成XML文档的各种方法,...

    Java对象序列化详细解析[参考].pdf

    Java对象序列化是一种将Java对象转换为字节流的过程,以便可以存储或在网络上传输。这一过程至关重要,因为它允许我们持久化对象的状态,以便在稍后的时间点恢复这些对象。在Java中,对象序列化主要涉及到`...

    java序列化对象传给php

    android(包括java)序列化一个对象传给php去做处理,或是接到php...//将一个对象序列化后返回byte[] String phpserialstr=new String(b); 将变量phpserialstr传给php即可. PHPSerializer中还有unserialize方法,是反序列化

    java对象序列化与反序列化的默认格式和json格式使用示例

    这就是Java对象序列化与反序列化的基本概念,以及如何与JSON格式结合使用的示例。在实际应用中,我们还需要考虑异常处理、性能优化以及安全性问题,比如使用`transient`关键字忽略某些字段,或者使用`@...

Global site tag (gtag.js) - Google Analytics