参考:https://blog.csdn.net/qq_27093465/article/details/78544505
1.定义
序列化:将对象转换成字符序列。
反序列化:将字符序列还原成对象。
2.到底什么场景中才真的需要序列化
(1):当想把内存中的对象保存到文件或者数据库中的时候。
(2):当想用套接字在网络上传输对象的时候。
(3):当想通过RMI传输对象的时候。
3.总结
当我们定义一个实体的时候,总是自然而然的实现序列化接口,生成序列化的id,但我们究竟什么时候用到,如果不做以上操作在什么场景下会抛出异常呢?
(1):当我们想将对象写到文件中,或者保存到数据库中的时候,如果没有对对象进行序列化操作,将会抛出NotSerializableException异常。
(2):当我们实现了序列化接口,对对象进行了序列化,之后对象中又添加了新的属性,这时反序列操作就会抛出InvalidClassException异常,这是因为我们没有生成序列化id,是系统为我们指定了序列化id,添加属性之后,导致序列化id改变,反序列时,id不一致导致的。
(3):transient修饰的字段和static字段不会进行序列化,transient序列化之后字段为null,static字段可通过序列化之后,修改static的值来进行测试。如果static字段参与序列化,那么反序列之后的值会覆盖我们修改的值。