您的位置:首页 > 编程语言 > Java开发

阿里___Java对象的序列化

2016-07-27 16:15 411 查看
今天也被问到如何进行序列化,我一时懵逼,觉得是让我实现一个库,后来我找了一下网上资料,所谓的对象的序列化大概意思就是实现一个接口而已。。。

不知道是不是面试官的问题。

代码参考 https://github.com/AceXIE/Serializable-example

下面引用一段话

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

  只能将支持 java.io.Serializable 接口的对象写入流中。每个 serializable 对象的类都被编码,编码内容包括类名和类签名、对象的字段值和数组值,以及从初始对象中引用的其他所有对象的闭包

1.概念

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

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

2.用途

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

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

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

3.对象序列化

3.1序列化API

  java.io.ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中。只有实现了Serializable和Externalizable接口的类的对象才能被序列化。

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

3.2代码示例
package serializable;

import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
import java.util.Date;

/***
* 阿里面试
* Java对象的序列化
* @author xiekai
*
*/
public class ObjectSaver {

public static void main(String[] args) throws ClassNotFoundException {
try {
//序列化对象
ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream("E:\\work_eclipse\\Serializable\\objectFile.obj"));

Customer customer = new Customer("xiekai", 24);
out.writeObject("Hello");
out.writeObject(new Date());
out.writeObject(customer);
out.close();

//反序列化
ObjectInputStream in = new ObjectInputStream(new FileInputStream("E:\\work_eclipse\\Serializable\\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);
in.close();

} catch (FileNotFoundException e) {
// TODO Auto-generated catch block
e.printStackTrace();
} catch (IOException e) {
// TODO Auto-generated catch block
e.printStackTrace();
}

}

}

class Customer implements Serializable {
private String name;
private int age;

public Customer(String name, int age) {
super();
this.name = name;
this.age = age;
}

@Override
public String toString() {
return "Customer [name=" + name + ", age=" + age + "]";
}

}


4.说明

  读取对象的顺序与写入时的顺序要一致

  对象的默认序列化机制写入的内容是:对象的类,类签名,以及非瞬态非静态字段的值。

下一篇

http://blog.csdn.net/xkzju2010/article/details/52061451
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: