内存中的数据对象只有转换二进制流才可以进行数据持久化和网络传输,将数据对象转换成二进制流的操作叫做序列化,反之叫做反序列化。
java原生的序列化方式是实现Serializable接口,这个接口非常特殊,没有任何方法,只是起到标识的作用。java序列化保留了对象类的元数据(类、成员变量、继承类信息等),以及数据对象,兼容性最好,但是不支持跨语言,而且性能一般。
使用java序列化时,建议设置serialVersionUID,因为Java的序列化机制是通过判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体类的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常,即是InvalidCastException。
如果不设置,那么在编译的过程中,编译器会根据类名、接口名、方法和属性等自动生成一个,这意味着如果我们在升级实体类时,这个serialVersionUID会变得,此时如果客户端设置了serialVersionUID则会无法反序列化成功。