Java序列化与反序列化三连问:是什么?为何要?如何作?

Java序列化与反序列化是什么?

Java序列化是指把Java对象转换为字节序列的过程,而Java反序列化是指把字节序列恢复为Java对象的过程:java

  • 序列化:对象序列化的最主要的用处就是在传递和保存对象的时候,保证对象的完整性和可传递性。序列化是把对象转换成有序字节流,以便在网络上传输或者保存在本地文件中。核心做用是对象状态的保存与重建。面试

  • 反序列化:客户端从文件中或网络上得到序列化后的对象字节流,根据字节流中所保存的对象状态及描述信息,经过反序列化重建对象。数据库

为何须要序列化与反序列化?

为何要序列化,那就是说一下序列化的好处喽,序列化有什么什么优势,因此咱们要序列化。网络

一:对象序列化能够实现分布式对象。多线程

主要应用例如:RMI(即远程调用Remote Method Invocation)要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时同样。分布式

二:java对象序列化不只保留一个对象的数据,并且递归保存对象引用的每一个对象的数据。this

能够将整个对象层次写入字节流中,能够保存在文件中或在网络链接上传递。利用对象序列化能够进行对象的"深复制",即复制对象自己及引用的对象自己。序列化一个对象可能获得整个对象序列。url

三:序列化能够将内存中的类写入文件或数据库中。spa

好比:将某个类序列化后存为文件,下次读取时只需将文件中的数据反序列化就能够将原先的类还原到内存中。也能够将类序列化为流数据进行传输。.net

总的来讲就是将一个已经实例化的类转成文件存储,下次须要实例化的时候只要反序列化便可将类实例化到内存中并保留序列化时类中的全部变量和状态。

四:对象、文件、数据,有许多不一样的格式,很难统一传输和保存。

序列化之后就都是字节流了,不管原来是什么东西,都能变成同样的东西,就能够进行通用的格式传输或保存,传输结束之后,要再次使用,就进行反序列化还原,这样对象仍是对象,文件仍是文件。

如何实现Java序列化与反序列化

首先咱们要把准备要序列化类,实现 Serializabel接口

例如:咱们要Person类里的name和age都序列化

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;
    }
}

 

而后:咱们将name和age序列化(也就是把这2个对象转为二进制,理解为“打碎”)

package org.lxh.SerDemo;

import java.io.File;
import java.io.FileOutputStream;
import java.io.ObjectOutputStream;


public class ObjectOutputStreamDemo { //序列化
    public static void main(String[] args) throws Exception {
        //序列化后生成指定文件路径
        File file = new File("D:" + File.separator + "person.ser");
        ObjectOutputStream oos = null;
        //装饰流(流)
        oos = new ObjectOutputStream(new FileOutputStream(file));

        //实例化类
        Person per = new Person("张三", 30);
        oos.writeObject(per); //把类对象序列化
        oos.close();
    }
}

 

一个很简单的示例,文章以应答面试提问为主,更深了解序列化与反序列化,须要你上网多参考资料。

好比:

《Java对象的序列化(Serialization)和反序列化详解》
http://www.javashuo.com/article/p-mbcgwvhd-ky.html

《Java 序列化的高级认识》
https://www.ibm.com/developerworks/cn/java/j-lo-serial/

好了,学起来!

最近三期

【15期】谈谈这几个常见的多线程面试题

【16期】你能谈谈HashMap怎样解决hash冲突吗

【17期】什么状况用ArrayList or LinkedList呢?

相关文章
相关标签/搜索