对象序列化,就是把一个对象变为二进制的数据流的一种方法,如图16-24所示,通过对象序列化可以方便的实现对象的传输或存储。
一个类的对象想被序列化,则对象所在的类必须实现java.io.Serializable接口。然而此接口并没有提供任何的抽象方法,所以该接口是一个标识接口,只是表示一种对象可以被序列化的能力。
范例:定义序列化对象类
package com.lxh.sixteenchapter;
import java.io.Serializable;
public class Member430 implements Serializable {
private String name;
private int age;
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
public int getAge() {
return age;
}
public void setAge(int age) {
this.age = age;
}
public Member430(String name, int age) {
this.name = name;
this.age = age;
}
@Override
public String toString() {
return "姓名"+this.name+"年龄"+this.age;
}
}
对象序列化与反序列化
对象序列化和反序列化的具体实现,依靠ObjectOutputStream与ObjectInputStream两类完成
ObjectOutputStream类可以将对象转为特定格式的二进制数据输出,ObjectInputStream类可以读取ObjectOutputStream类输出的二进制对象数据,并将其转为具体类型的对象返回。
ObjectOutputStream常用方法
ObjectInputStream常用方法
范例:实现对象序列化和反序列化操作
package com.lxh.sixteenchapter;
import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
public class javaIODemo432 {
//本次操作要将序列化的对象保存到文件中,将文件定义为公共常量
private static final File SAVE_FILE=new File("E:"+File.separator+"File"+File.separator+"1.txt");
public static void main(String[] args) throws FileNotFoundException, IOException, ClassNotFoundException {
saveObject(new Member430("小李",18)); //对象序列化
System.out.println(loadObject()); //反序列化
}
private static Object loadObject() throws FileNotFoundException, IOException, ClassNotFoundException {
ObjectInputStream ois=new ObjectInputStream(new FileInputStream(SAVE_FILE));
Object obj=ois.readObject(); //反序列
ois.close();
return obj;
}
private static void saveObject(Object obj) throws FileNotFoundException, IOException {
ObjectOutputStream oos=new ObjectOutputStream(new FileOutputStream(SAVE_FILE));
oos.writeObject(obj); //序列化
oos.close();
}
}
执行结果
序列化:会转换为二进制数据
反序列化
姓名小李年龄18
transient关键字
transient可以使某些成员属性不进行序列化
默认情况下,当执行对象序列化的时候,会将类中的全部属性进行序列化操作,但有一些属性不需要进行序列化操作(例如动态需要计算的),这个时候就可以使用transient关键字来完成。没有序列化的属性在反序列化时读取的数据类型为默认操作。例如name为null。
@SuppressWarnings("serial") // 序列化需要有一个序列化编号,该编号编译时可以自动生成
class Member implements Serializable {
private transient String name ;// 此属性不被序列化
private int age ;
// 其它相同代码略 ...
}