java中的serialVersionUID。 如果在本地的两个类中声明了两个值相同的这个变量,会有啥问题吗?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了java中的serialVersionUID。 如果在本地的两个类中声明了两个值相同的这个变量,会有啥问题吗?相关的知识,希望对你有一定的参考价值。
如果自己声明的这个变量和jar包里的相同又会有问题吗?
简单来说,Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。当实现java.io.Serializable接口的实体(类)没有显式地定义一个名为serialVersionUID,类型为long的变量时,Java序列化机制会根据编译的class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,只有同一次编译生成的class才会生成相同的serialVersionUID 。
如果我们不希望通过编译来强制划分软件版本,即实现序列化接口的实体能够兼容先前版本,未作更改的类,就需要显式地定义一个名为serialVersionUID,类型为long的变量,不修改这个变量值的序列化实体都可以相互进行串行化和反串行化。
serialVersionUID主要来判断不同版本的兼容性。
当在反序列化的时候,字节流中的版本号,就和serialVersionUID区比较,而生成它的对象。
如果你没有设置,java序列化机制,也自动会给你分配一个。
其实这个东西没必要去考虑!
请参考 参考技术A 不会吧,求高手来详细说明下 参考技术B 不会
面试题:serialVersionUID
问:serialVersionUID有何用途?如果没定义会有什么问题?
解:序列化是将对象的状态信息转换为可存储或传输的形式的过程。我们都知道,Java对象是保存在JVM的堆内存中的,也就是说,如果JVM堆不存在了,那么对象也就跟着消失了。
而序列化提供了一种方案,可以让你在即使JVM停机的情况下也能把对象保存下来的方案。就像我们平时用的U盘一样。把JAVA对象序列化成可存储或传输的形式(如二进制流),比如保存在文件中。这样,当再次需要这个对象的时候,从文件中读取出二进制流,再从二进制流中反序列化出对象。
但是,虚拟机是否允许反序列化,不仅取决于类路径和功能代码是否一致,一个非常重要的一点是两个类的序列化ID是否一致,即serialVersionUID要求一致。
在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体类的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常,即使InvalidCastException。这样做是为了保证安全,因为文件存储中的内容可能被篡改。
当实现java.io.Serializable接口的类没有显式地定义一个serialVersionUID变量时候,JAVA序列化机制会根据编译的Class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,如果Class文件没有发生变化,就算再编译多次,serialVersionUID也不会变化的。但是,如果发生了变化,那么这个文件对应的serialVersionUID也就会发生变化。
基于以上原理,如果我们一个类实现了Serializable接口,但是没有定义serialVersionUID,然后序列化。在序列化之后,由于某些原因,我们对该类做了变更,重新启动应用后,我们相对之前序列化过的对象进行反序列化的话就会报错。
以上是关于java中的serialVersionUID。 如果在本地的两个类中声明了两个值相同的这个变量,会有啥问题吗?的主要内容,如果未能解决你的问题,请参考以下文章
java中的serialVersionUID是啥,通常在异常类中? [复制]
跨不同 JVM 的 Java 标准库中的 SerialVersionUID
为啥java中的serialVersionUID必须是静态的、最终的和long类型的? [复制]