java序列化:Serializable
需要了解:
1、什么是java序列化和反序列化
2、如何实现java序列化和反序列化
3、什么时候需要序列化
一、序列化和反序列化
序列化:把对象转换为字节序列的过程称为对象的序列化。
反序列化:把字节序列恢复为对象的过程称为对象的反序列化。
序列化通俗的解释就是一类对象的集合,很多的对象数据,这些数据中,有些信息我们想让他持久的保存起来,就是把内存里面的这些对象给变成一连串的字节描述的过程,常见的就是变成文件。
反序列化就是把保存文件的啥解析还原成一个对象。
二、实现序列化
类通过实现 java.io.Serializable 接口以启用其序列化功能。
未实现此接口的类将无法使其任何状态序列化或反序列化。
可序列化类的所有子类型本身都是可序列化的。因为实现接口也是间接的等同于继承。
序列化接口没有方法或字段,仅用于标识可序列化的语义。
java bean实现序列化接口:
public class SpiderMan implements
Serializable{
private static final long serialVersionUID = 1L;
private static int age = 20;
private String name;
private String nation;
transient String life;
序列化:
private static void serializeSpiderMan() throws
FileNotFoundException, IOException{
SpiderMan sm = new SpiderMan();
// ObjectOutputStream 对象输出流,将SpiderMan对象存储到C盘的 fly.txt 文件中,完成对
SpiderMan 对象的序列化操作
sm.setLife("LOVE FREEDOM");
sm.setName("HANKS");
sm.setNation("ENGLAND");
ObjectOutputStream oos = new ObjectOutputStream(new
FileOutputStream(new File("c://fly.txt")));
oos.writeObject(sm);
System.out.println("序列化");
oos.close();
}
反序列化:
private static SpiderMan deserializeSpiderMan() throws
FileNotFoundException, IOException, ClassNotFoundException {
ObjectInputStream ois = new ObjectInputStream(new
FileInputStream(new File("c://fly.txt")));
SpiderMan s = (SpiderMan)ois.readObject();
System.out.println("反序列化");
ois.close();
return s;
}
三、何时序列化
当你想把的内存中的对象状态保存到一个文件中或者数据库中时候;
当你想用套接字在网络上传送对象的时候;
当你想通过RMI传输对象的时候;
关于 serialVersionUID 的描述
序列化运行时使用一个称为 serialVersionUID
的版本号与每个可序列化类相关联,该序列号在反序列化过程中用于验证序列化对象的发送者和接收者是否为该对象加载了与序列化兼容的类。如果接收者加载的该对象的类的
serialVersionUID 与对应的发送者的类的版本号不同,则反序列化将会导致
InvalidClassException。可序列化类可以通过声明名为 "serialVersionUID" 的字段(该字段必须是静态
(static)、最终 (final) 的 long 型字段)显式声明其自己的 serialVersionUID:
如果可序列化类未显式声明 serialVersionUID,则序列化运行时将基于该类的各个方面计算该类的默认
serialVersionUID 值,如“ 对象序列化规范”中所述。不过,强烈建议 所有可序列化类都显式声明
serialVersionUID 值,原因是计算默认的 serialVersionUID
对类的详细信息具有较高的敏感性,根据编译器实现的不同可能千差万别,这样在反序列化过程中可能会导致意外的
InvalidClassException。因此,为保证 serialVersionUID 值跨不同 java
编译器实现的一致性,序列化类必须声明一个明确的 serialVersionUID 值。还强烈建议使用 private 修饰符显示声明
serialVersionUID(如果可能),原因是这种声明仅应用于直接声明类 -- serialVersionUID
字段作为继承成员没有用处。数组类不能声明一个明确的 serialVersionUID,因此它们总是具有默认的计算值,但是数组类没有匹配
serialVersionUID 值的要求。