概念
序列化:将对象转换成二进制序列,能够存储到硬盘上
反序列化:将二进制序列转成对象.
序列化的作用
例如在Web的数据传输过程中,都是以二进制序列传输的,JVM接收到的都是二进制序列,只是JVM帮我们把二进制序列转换成了对象.但有些情况,例如tomcat存储Session的过程中,如果有十万个用户并发访问,这个时候我们如果把这么多的session对象都放入内存开销太大,这个时候可以利用序列化,将session进行二进制序列存储到硬盘中,当用的时候再获取.
序列化代码实现
- 定义序列化对象
public class Person implements Serializable{
public static final long serialVersionUID = 1L;
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = 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;
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
- 实现序列化和反序列化
public class SerializableDemo {
public static void main(String[] args) throws IOException, ClassNotFoundException {
//序列化,文件输出流指的是JVM向外输出,由输出流写入本地文件
FileOutputStream fileOutputStream = new FileOutputStream("out.text");
ObjectOutputStream objectOutputStream = new ObjectOutputStream(fileOutputStream);
Person person = new Person("张三", 10);
objectOutputStream.writeObject(person);
objectOutputStream.close();
//反序列化
FileInputStream fileInputStream = new FileInputStream("out.text");
ObjectInputStream objectInputStream = new ObjectInputStream(fileInputStream);
Object o = objectInputStream.readObject();
System.out.println(o);
}
}