serialVersionUID 的 warring 的问题


package com.test.interceptor;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;

public class MyInterceptor implements Interceptor {

public void destroy() {
System.out.println("MyInterceptor destroy");
}

public void init() {
System.out.println("MyInterceptor init");
}

public String intercept(ActionInvocation invocation) throws Exception {
System.out.println("MyInterceptor intercept");
invocation.invoke();
return null;
}

}



package com.test.interceptor;

import com.opensymphony.xwork2.ActionInvocation;
import com.opensymphony.xwork2.interceptor.Interceptor;

public class MyInterceptor implements Interceptor {

/**
* serialVersionUID MyInterceptor
*/
private static final long serialVersionUID = 1L;

public void destroy() {
System.out.println("MyInterceptor destroy");
}

public void init() {
System.out.println("MyInterceptor init");
}

public String intercept(ActionInvocation invocation) throws Exception {
System.out.println("MyInterceptor intercept");
invocation.invoke();
return null;
}

}

===============================================================================
用Eclipse的IDE环境中实现序列化,在Problems中会出来好多类似 serialVersionUID的警告。当采用程序的自动修复时,采用默认方式,Eclipse会加上:private static final long serialVersionUID = 1L; 其实这个问题倒也不影响程序的运行,但是我看到Problems里面有警告就不舒服,同时也说明我们写的代码还是不规范。具体的原因还就是和序列化中的这个serialVersionUID有关。[b]serialVersionUID 用来表明类的不同版本间的兼容性[/b]。如果你修改了此类, 要修改此值。否则以前用老版本的类序列化的类恢复时会出错。在JDK中,可以利用JDK的bin目录下的serialver.exe工具产生这个 serialVersionUID,对于Test.class,执行命令:serialver Test。[b]为了在反序列化时,确保类版本的兼容性,最好在每个要序列化的类中加入private static final long serialVersionUID这个属性,具体数值自己定义[/b]。这样,即使某个类在与之对应的对象已经序列化出去后做了修改,该对象依然可以被正确反序列化。否则,如果不显式定义该属性,这个属性值将由JVM根据类的相关信息计算,而修改后的类的计算结果与修改前的类的计算结果往往不同,从而造成对象的反序列化因为类版本不兼容而失败。不显式定义这个属性值的另一个坏处是,不利于程序在不同的JVM之间的移植。因为不同的编译器实现该属性值的计算策略可能不同,从而造成虽然类没有改变,但是因为JVM不同,出现因类版本不兼容而无法正确反序列化的现象出现。当我们的系统不太经常需要序列化类时,可以去掉这些警告,做如下设置:Window(窗口)-->Preferences(首选项)-->Java-->编译器-->错误/警告,将serializable class without serialVersionUID的设置由warning改为Ignore。然后Eclipse会重新编译程序,那些警告信息也就消失了。最后的建议是,如果我们开发大量需要序列化的类的时候,我们最好还是还原为原来的设置。
============================================补充
例子中 Interceptor 继承 Serializable 而 java.io.Serializable 接口的类是可序列化的所有出现serialVersionUID 相关的反序列化问题.
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值