一、概念:所谓序列化就是将对象转为字节流的过程(把对象写到指定文件中)
反序列化则是将字节流转换为对象的过程。(从文件中读取对象)
作用:
1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中;
2) 在网络上传送对象的字节序列。
二、涉及场景
最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些session先序列化到硬盘中,等要用了,再把保存在硬盘中的对象还原到内存中。
当两个进程在进行远程通信时,彼此可以发送各种类型的数据。无论是何种类型的数据,都会以二进制序列的形式在网络上传送。发送方需要把这个Java对象转换为字节序列,才能在网络上传送;接收方则需要把字节序列再恢复为Java对象。
三、如何实现
1, 对象序列化流 java.io.ObjectOutputStream
构造方法:ObjectOutputStream(OutputStream out) 创建写入指定OutputStream的ObjectOutputStream。
方法:void writeObject(Object object) 将指定的对象写入ObjectOutputStream。
2,对象反序列化流java.io.ObjectInputStream
构造方法:ObjectInputStream(InputStream in) 创建从指定InputStream 读取的ObjectInputStream。
方法:void ReadObject(Object object) 从ObjectInputStream读取对象
四、注意点
1、当一个对象要能被序列化,这个对象所属的类必须实现Serializable接口,当实现Serializable接口后jvm会为该类.class文件生成唯一serialVersionUID。当序列化时也会将此ID写入文件。在序列化后,如果后续有改动此文件serialVersionUID也会变,反序列化时则因serialVersionUID不同而报错。定义一个 private static final long serialVersionUID = 2L;可避免。
2、当一个类的对象被序列化时,某些属性不需要被序列化,可以使用关键字transient修饰。private transient int age;
3、静态成员不可被序列化(静态成员属于类,是对象的共享数据),序列化与反序列化是针对对象的