package cn.dali3.code24;
import java.io.*;
/*序列化与反序列化
*
* 序列化:把对象以流的方式写入到文件中保存。(也叫做写对象)
* 反序列化:把文件中以流的方式保存的对象读取出来。(也叫做读对象)
*
* ObjectOutputStream 对象的序列化流
* 构造方法 ObjectOutputStream(OutputStream out)
* 该类也是以字节的方式写入到文本中的。因为对象中不只有字符,所以我们使用字节。
*
* 特有成员方法:
* void writeObject(Object obj) 把指定的对象写入到流中
* 使用步骤:
* 1.创建ObjectOutputStream对象,构造方法中传递字节输出流
* 2.调用writeObject方法,把对象写入到文本中
* 3.释放资源
*
* 注:
* 我们对传递的对象是有要求的,他的类必须是实现了Serializable接口的。
* 该接口就是一个标记性接口
* 当我们进行序列化或者反序列化的时候,就会检测对象是否实现了该接口
* 如果没有实现就会抛出NotSerializable异常
* 实现了就可以继续使用
*
*
*
* ObjectInputStream 对象的反序列化流
*
* 特有成员方法 Object readObject()
* 注:该方法会抛出异常 classNotFound
* 必要条件:
* 1.必须存在要读取对象的类。
* 2.类必须实现了Serializable接口
*
* 注意:被static和transient修饰的不可以被序列化,序列化只可以是对象。
*
* 异常 InvalidClassException
* 当我们对一个对象进行序列化后,又改变了他的类,进行反序列化的时候会抛出异常 InvalidClassException
* 因为,当我们创建了一个实现了Serializable接口的类后,java编译器会把Person.java 编译生成.class文件
* 同时会给.class文件添加一个序列号:serialVersionUID 该序列号也会被传递进入到我们要写入的文本中。
* 当我们进行反序列化的时候,首先会对比文本中对象的序列号和程序中class序列号是否相同,如果类被改变了
* 则序列号也会改变,所以会检测到对象和class序列号不同,就会抛出该异常。*
*
* 解决办法
* 我们在继承Serializable的类中,手动定义一个静态的(static)不可改变的(final)Long类型的序列号(SerialVersionUID)*/
public class Demo01 {
public static void main(String[] args) throws IOException, ClassNotFoundException {
ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("C:\\Users\\Administrator\\Desktop\\111.TXT"));
oos.writeObject(new Person("山下美月"));
oos.close();
ObjectInputStream ois = new ObjectInputStream(new FileInputStream("C:\\Users\\Administrator\\Desktop\\111.TXT"));
System.out.println(ois.readObject());
ois.close();
}
}
Person类
package cn.dali3.code24;
import java.io.Serializable;
import java.util.Objects;
public class Person implements Serializable{
private static final long SerialVersionUID = 1L;
private String name;
public Person() {
}
public Person(String name) {
this.name = name;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
'}';
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Person person = (Person) o;
return Objects.equals(name, person.name);
}
@Override
public int hashCode() {
return Objects.hash(name);
}
}