java中序列化和反序列化

参考: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字段参与序列化,那么反序列之后的值会覆盖我们修改的值。

猜你喜欢

转载自blog.csdn.net/m0_37438942/article/details/84988974