java序列化和反序列化以及serialVersionUID的作用(一)

2014-11-24 07:51:15 · 作者: · 浏览: 3

当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。

把Java对象转换为字节序列的过程称为对象的序列化。

把字节序列恢复为Java对象的过程称为对象的反序列化。

对象的序列化主要有两种用途:

1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;

2) 在网络上传送对象的字节序列。

一.JDK类库中的序列化API

java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。

java.io.ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回。、

只有实现了Serializable和Externalizable接口的类的对象才能被序列化。Externalizable接口继承自Serializable接口,实现Externalizable接口的类完全由自身来控制序列化的行为,而仅实现Serializable接口的类可以采用默认的序列化方式 。

对象序列化包括如下步骤:

1) 创建一个对象输出流,它可以包装一个其他类型的目标输出流,如文件输出流;

2) 通过对象输出流的writeObject()方法写对象。

对象反序列化的步骤如下:

1) 创建一个对象输入流,它可以包装一个其他类型的源输入流,如文件输入流;

2) 通过对象输入流的readObject()方法读取对象。

下面让我们来看一个对应的例子,类的内容如下:

ObjectServer.java

package com.liao;
import java.io.*;
import java.util.Date;
/**
 * Created with IntelliJ IDEA.
 * User: Administrator
 * Date: 13-12-11
 * Time: 下午5:08
 * To change this template use File | Settings | File Templates.
 * @see对象的序列化    从输入流中读取数据的顺序(类型)要和写入流时候的顺序对应
 */
public class ObjectServer {
    private static String hello="你好";
    private static int number =1234;
    public static void main(String[] args) throws Exception {
        ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("D:\\objectFile.obj"));
        //序列化对象
        Customer customer = new Customer("阿蜜果", 24,"GuangZhouChina");
        out.writeObject(hello);
        out.writeObject(new Date());
        out.writeObject(customer);
        out.writeInt(number);
        out.writeInt(123); //写入基本类型数据
        out.close();
    }
}

class Customer implements Serializable {
    private static final long serialVersionUID=1324123542315L;
    private String name;
    private int age;
    private String address;
    public Customer(String name, int age,String address) {
        this.name = name;
        this.age = age;
        this.address=address;
    }
    public String toString() {
        return "name=" + name + ", age=" + age+", address="+address;
    }
}

ObjectClient.java

package com.liao;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.util.Date;
/**
 * @see反序列化测试类.
 * Created with IntelliJ IDEA.
 * User: Administrator
 * Date: 13-12-11
 * Time: 下午5:16
 * To change this template use File | Settings | File Templates.
 */
public class ObjectClient {
    public static void main(String[] args){
        //反序列化对象
        try{
            ObjectInputStream in = new ObjectInputStream(new FileInputStream("D:\\objectFile.obj"));
            System.out.println("obj1=" + (String) in.readObject());
            System.out.println("obj2=" + (Date) in.readObject());
            Customer obj3 = (Customer) in.readObject();
            System.out.println("obj3=" + obj3);
            int obj4 = in.readInt();
            System.out.println("obj4=" + obj4);
            int obj5 = in.readInt();
            System.out.println("obj5="+obj5);
            in.close();

        } catch (ClassNotFoundException enf)  {
            System.out.println("ClassNotFound");
            enf.printStackTrace();
        }catch(IOException e){
            e.printStackTrace();
        }
    }

}

输出结果如下:

obj1=你好
obj2=Wed Dec 11 17:38:55 CST 2013
obj3=name=阿蜜果, age=24, address=GuangZhou
obj4=1234
obj5=123

因此例比较简单,在此不再详述。

序列化、反序列化为XML文件,使用了XStream来序列化,需要引入xstream-1.3.1.jar包的支持,
http://xstream.codehaus.org/download.html 处可以 下载jar

package com.liao;
import com.thoughtworks.x