Java的序列化

2014-11-24 08:29:28 · 作者: · 浏览: 0

1.序列化理解成“打碎”是可以的,不过在书本上的名词就是将对象转换成二进制。一般用于将对象通过网络传输、保存成文件或写入数据库中,打碎后更易搬运或I/O;

2.序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化。可以对流化后的对象进行读写操作,也可将流化后的对象传输于网络之间。序列化是为了更易于对对象流进行读写操作或网络传输;

3.客户端A中的数据要转换成二级制字节,才能在网络中传输,客户端B收到后再转换成数据。这个过程就是序列化和反序列化,前者或叫写出,后者或叫读取;

4.如果要将对象通过网络传输或保存成本地文件,就必须将其序列化;

5.序列化以后对象,就变成了2进制的文件,也就是可以储存和传输。有2个好处:1) 如果是应用程序的话每次都把对象保持在文件里的话就不怕突然停电,下次启动你可以直接从文件里读出来最新的对象信息。2)RMI,EJB等实现基础就是对象的序列化;

6.如果某个类能够被序列化,其子类也可以被序列化。声明为static和transient类型的成员数据不能被序列化。因为static代表类的状态, transient代表对象的临时数据;

7.什么时候使用序列化:一:对象序列化可以实现分布式对象。主要应用例如:RMI要利用对象序列化运行远程主机上的服务,就像在本地机上运行对象时一样。二:java对象序列化不仅保留一个对象的数据,而且递归保存对象引用的每个对象的数据。可以将整个对象层次写入字节流中,可以保存在文件中或在网络连接上传递。利用对象序列化可以进行对象的"深复制",即复制对象本身及引用的对象本身。序列化一个对象可能得到整个对象序列;

8.序列化的实现:将需要被序列化的类实现Serializable接口,该接口没有需要实现的方法,implements Serializable只是为了标注该对象是可被序列化的,然后使用一个输出流(如:FileOutputStream)来构造一个ObjectOutputStream(对象流)对象,接着,使用ObjectOutputStream对象的writeObject(Object obj)方法就可以将参数为obj的对象写出(即保存其状态),要恢复的话则用输入流。也可以说,只需要两个单词,就可以搞定序列化操作:implements Serializable。见以下代码:

[java]
首先我们要把准备要序列化类,实现 Serializabel接口
例如:我们要Person类里的name和age都序列化
import java.io.Serializable;

public class Person implements Serializable { //本类可以序列化,implements Serializable要写不然下面ObjectOutputStreamDemo.java执行报异常
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 ;
}
}
[java]
然后:我们将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() ;
}
}

作者:berber78