关于The serializable class XXX does not declare a static final serialVersionUID field of type long的警告...

  最近在研究Java与Flex用Json交换数据,也就是Java对象转换成Json传送到客户端之后,再转换成ActionScript对象,研究通透了我会写博文将方法告诉大家。
  
  
  
  
  
  
  
  
  
  
  
  我们在编程的时候经常遇到这个警告,很多时候我们都是用Eclipse自动生成一个UID,很少去思考这个UID是用来干什么的,今天早上上班我突然对这个问题有求知欲,嘿嘿,就Google了一下(Google和baidu都行)。
  结论如下:
  【现象】
  当你一个类实现了Serializable接口,如果没有定义serialVersionUID,Eclipse会提供这个提示功能告诉你去定义之。
  【serialVersionUID的作用】
  serialVersionUID 用来表明类的不同版本间的兼容性。如果你修改了此类, 要修改此值。否则以前用老版本的类序列化的类恢复时会出错。 在JDK中,可以利用JDK的bin目录下的serialver.exe工具产生这个serialVersionUID,对于Test.class,执行 命令:serialver Test。
  为了在反序列化时,确保类版本的兼容性,最好在每个要序列化的类中加入 private static final long serialVersionUID这个属性,具体数值自己定义。这样,即使某个类在与之对应的对象 已经序列化出去后做了修改,该对象依然可以被正确反序列化。否则,如果不显式定义该属性,这个属性值将由JVM根据类的相关信息计算,而修改后的类的计算 结果与修改前的类的计算结果往往不同,从而造成对象的反序列化因为类版本不兼容而失败。
  不显式定义这个属性值的另一个坏处是,不利于程序在不同的JVM之间的移植。因为不同的编译器实现该属性值的计算策略可能不同,从而造成虽然类没有改变, 但是因为JVM不同,出现因类版本不兼容而无法正确反序列化的现象出现。
  【结论】
  各位大侠,在编程的时候还是不要偷懒了,还是把这个UID加上吧,说不准哪天程序崩溃了就是由于没有定义这个UID。
  关于为什么要序列化,可以查看我前年写的一篇文章:http://blog.csdn.net/virgoboy2004/archive/2008/06/ 13/2544939.aspx

你可能感兴趣的:(技术杂绘)