序列化主要用于涉及到流的地方,一般存储及读取文件,或者进行远程传输时都会涉及到流。
对于自己建的java对象POJO,如果不实现序列化的话,无法进行流传输。
实现序列化只需要实现一个接口implements Serializable。
在实现后,一定要声明一个
private static final long serialVersionUID = 1L;
如果不声明,系统会自动分配一个,但是代码版本调整的时候有可能发生变动。
而一旦变动,在读取反序列化之前版本的数据时会报以下错误:
java.io.InvalidClassException: net.jy.redis.pojo.User; local class incompatible: stream classdesc serialVersionUID = -3418623797767119694, local class serialVersionUID = 1
建议实现序列化接口时,直接声明好serialVersionUID 。在以后代码更新中,只要和之前版本有联系,serialVersionUID 就不能进行修改,否则无法序列化或反序列化之前序列化流