和其他OO语言一样,Java可以把Object转换成数据流,存储在硬盘上,也可以把读出硬盘数据并转换成对象,这叫做Object Serialization(对象串行化)。
如果一个类要实现Serialization,则必须implements接口Serializable。
接口Serializable并没有定义方法。它只是一个标记接口,向编译器和JVM 说明此对象可以Serialized。
关键字transient声明的变量不参加串行化。
类ObjectInputStream和ObjectOutputStream封装了串行化数据的读写方法。
ObjectInputStream.readObject(); //从流中读取对象
ObjectOutputStream.writeObject(Object object); //向流中写入对象
import java.io.*;

class T implements Serializable ...{
int a = 0 ;
int b = 0 ;
transient int c = 10 ; //transient声明的变量不被串行化
}

public class ObjectSerialize ...{
public static void main(String[] args) throws Exception ...{
T t = new T() ;
t.a = 1 ;
t.b = 2 ;
t.c = 3 ;
FileOutputStream fos = new FileOutputStream("SerializedObject.dat");
ObjectOutputStream oos = new ObjectOutputStream(fos);
oos.writeObject(t);
oos.flush();
oos.close();
FileInputStream fis = new FileInputStream("SerializedObject.dat");
ObjectInputStream ois = new ObjectInputStream(fis);
T readedT = (T)ois.readObject();
System.out.println(readedT.a);
System.out.println(readedT.b);
System.out.println(readedT.c);
}
}1
2
0
本文介绍Java中对象串行化的实现方法,包括如何通过实现Serializable接口使类支持串行化,以及使用ObjectInputStream和ObjectOutputStream类进行对象的读写操作。
700

被折叠的 条评论
为什么被折叠?



