public class LoginActionForm extends ActionForm {
/**
*
*/
private static final long serialVersionUID = 1L;
新创建一个类 LoginActionForm 就警告,为什么一定要
private static final long serialVersionUID = 1L;
有什么必要的么?
7 个解决方案
#1
这是串行化序列号。
以下是百度知道的回答:
以下是百度知道的回答:
简单来说,Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。
当实现java.io.Serializable接口的实体(类)没有显式地定义一个名为serialVersionUID,类型为long的变量时,Java序列化机制会根据编译的class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,只有同一次编译生成的class才会生成相同的serialVersionUID 。
如果我们不希望通过编译来强制划分软件版本,即实现序列化接口的实体能够兼容先前版本,未作更改的类,就需要显式地定义一个名为serialVersionUID,类型为long的变量,不修改这个变量值的序列化实体都可以相互进行串行化和反串行化。
#2
不是必须写的,可以在eclipse->Window->Preferences->java->Compiler->Errors/Warnings中设置
#3
如果不用序列话的话 可以在类前面加上
去除警告信息
@SuppressWarnings("serial")
去除警告信息
#4
里面有很多设置 分不清是哪个了 指明下~~~~~
#5
如果你这个LoginActionForm需要序列化和被反序列化的话应该加上,不过对于STRUTS的form应该不需要吧
#6
反正我觉得这个东西是不一定都要加的 具体情况在分析吧!
#7
找到Serializable class without serialVersionUID将Warning改为Ignore即可
#1
这是串行化序列号。
以下是百度知道的回答:
以下是百度知道的回答:
简单来说,Java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体(类)的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常。
当实现java.io.Serializable接口的实体(类)没有显式地定义一个名为serialVersionUID,类型为long的变量时,Java序列化机制会根据编译的class自动生成一个serialVersionUID作序列化版本比较用,这种情况下,只有同一次编译生成的class才会生成相同的serialVersionUID 。
如果我们不希望通过编译来强制划分软件版本,即实现序列化接口的实体能够兼容先前版本,未作更改的类,就需要显式地定义一个名为serialVersionUID,类型为long的变量,不修改这个变量值的序列化实体都可以相互进行串行化和反串行化。
#2
不是必须写的,可以在eclipse->Window->Preferences->java->Compiler->Errors/Warnings中设置
#3
如果不用序列话的话 可以在类前面加上
去除警告信息
@SuppressWarnings("serial")
去除警告信息
#4
里面有很多设置 分不清是哪个了 指明下~~~~~
#5
如果你这个LoginActionForm需要序列化和被反序列化的话应该加上,不过对于STRUTS的form应该不需要吧
#6
反正我觉得这个东西是不一定都要加的 具体情况在分析吧!
#7
找到Serializable class without serialVersionUID将Warning改为Ignore即可