Java中对象的串行化(Serialization)和transient关键字
package?chb.demo.test;
import?java.io.Serializable;
public?class?Student?implements?Serializable?{
????int?id;?//?学号
????String?name;?//?姓名
????int?age;?//?年龄
????String?department;?//?系别
????public?Student(int?id,?String?name,?int?age,?String?department)?{
????????this.id?=?id;
????????this.name?=?name;
????????this.age?=?age;
????????this.department?=?department;
????}
}
2.构造对象的输入/输出流
要串行化一个对象,必须与一定的对象输出/输入流联系起来,通过对象输出流将对象状态保存下来,再通过对象输入流将对象状态恢复。
java.io包中,提供了ObjectInputStream和ObjectOutputStream将数据流功能扩展至可读写对象 。在ObjectInputStream 中用readObject()方法可以直接读取一个对象,ObjectOutputStream中用writeObject()方法可以直接将对象保存到输出流中。
package?chb.demo.test;
import?java.io.IOException;
import?java.io.FileOutputStream;
import?java.io.FileInputStream;
import?java.io.ObjectOutputStream;
import?java.io.ObjectInputStream;
public?class?ObjectSer?{
????public?static?void?main(String?args[])?throws?IOException,
????????????ClassNotFoundException?{
????????Student?stu?=?new?Student(981036,?"chb",?23,?"CSD");
????????FileOutputStream?fo?=?new?FileOutputStream("D:/data.txt");
????????ObjectOutputStream?so?=?new?ObjectOutputStream(fo);
????????try?{
????????????so.writeObject(stu);
????????????so.close();
????????}?catch?(IOException?e)
????????{
????????????System.out.println(e);
????????}
????????stu?=?null;
????????FileInputStream?fi?=?new?FileInputStream("D:/data.txt");
????????ObjectInputStream?si?=?new?ObjectInputStream(fi);
????????try?{
????????????stu?=?(Student)?si.readObject();
????????????si.close();
????????}?catch?(IOException?e)
????????{
????????????System.out.println(e);
????????}
????????System.out.println("Student?Info:");
????????System.out.println("ID:"?+?stu.id);
????????System.out.println("Name:"?+?stu.name);
????????System.out.println("Age:"?+?stu.age);
????????System.out.println("Dep:"?+?stu.department);
????}
}运行结果如下:
ID:981036
Name:chb
Age:23
Dep:CSD
在这个例子中,我们首先定义了一个类Student,实现了Serializable接口 ,然后通过对象输出流的writeObject()方法将Student对象保存到文件 data.txt中 。之后,通过对象输入流的readObjcet()方法从文件data.ser中读出保存下来的Student对象 。从运行结果可以看到,通过串行化机制,可以正确地保存和恢复对象的状态。
三、串行化的注意事项
1.串行化能保存的元素
串行化只能保存对象的非静态成员交量,不能保存任何的成员方法和静态的成员变量,而且串行化保存的只是变量的值,对于变量的任何修饰符都不能保存。
对于某些类型的对象,其状态是瞬时的,这样的对象是无法保存其状态的。例如一个Thread对象或一个FileInputStream对象 ,对于这些字段,我们必须用transient关键字标明,否则编译器将报措。另外 ,串行化可能涉及将对象存放到磁盘上或在网络上发送数据,这时候就会产生安全问题。因为数据位于Java运行环境之外,不在Java安全机制的控制之中。对于这些需要保密的字段,不应保存在永久介质中 ,或者不应简单地不加处理地保存下来 ,为了保证安全性。应该在这些字段前加上transient关键字。