Object Serialization and ObjectInputStream/ObjectOutputStream -Java 学习笔记 (27)

来源:互联网 发布:自我意识觉醒 知乎 编辑:程序博客网 时间:2024/05/16 16:00

和其他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