java private 1l_创建servlet类时出现的“private static final long serialVersionUID = 1L;”语句是什么意思啊?...

实现java.io.Serializable这个接口是为序列化,serialVersionUID 用来表明实现序列化类的不同版本间的兼容性。如果你修改了此类, 要修改此值。

否则以前用老版本的类序列化的类恢复时会出错。

实现后如果你用的是工具的话会出来警告,他会提示你,可以自动生成private static final long serialVersionUID = 1L; 为了在反序列化时,

确保类版本的兼容性,最好在每个要序列化的类中加入private static final long serialVersionUID这个属性,具体数值自己定义.

在JDK中,可以利用JDK的bin目录下的serialver.exe工具产生这个serialVersionUID,如对于Test.class可执行如下命令:serialver Test。

这样,即使某个类在与之对应的对象已经序列化出去后做了修改,该对象依然可以被正确反序列化。否则,如果不显式定义该属性,

这个属性值将由JVM根据类的相关信息计算,而修改后的类的计算结果与修改前的类的计算结果往往不同,从而造成对象的反序列化因为类版本不兼容而失败。

不显式定义这个属性值的另一个坏处是,不利于程序在不同的JVM之间的移植。因为不同的编译器实现该属性值的计算策略可能不同,

从而造成虽然类没有改变,但是因为JVM不同,出现因类版本不兼容而无法正确反序列化的现象出现。 当我们的系统不太经常需要序列化类时,

可以去掉这些警告,做如下设置:Window-->Preferences-->Java,将serializable class without serialVersionUID的设置由warning改为Ignore。

然后Eclipse会重新编译程序,那些警告信息也就消失了。

最后的建议是,如果我们开发大量需要序列化的类的时候,我们最好还是还原为原来的设置。这样可以保证系统的性能和健壮。

关于serialVersionUID的解释

serialVersionUID作用: 序列化时为了保持版本的兼容性,即在版本升级时反序列化仍保持对象的唯一性。

你可以随便写一个,在Eclipse中它替你生成一个,有两种生成方式: 一个是默认的1L,比如:private static final long serialVersionUID = 1L;

一个是根据类名、接口名、成员方法及属性等来生成一个64位的哈希字段,

比如:private static final long serialVersionUID = -8940196742313994740L;之类的。

Eclipse提示The serializable class XXX does not declare a static final serialVersionUID field of type long 那是Eclipse提供这个提示功能给你吧.

你点它warning的icon两下Eclipse就会自动给定.

如果你不喜欢,可以把它关掉, windows -> preferences -> compiler -> Error/Warnings -> Potential Programming problems 将Serializable class without serialVersionUID的warning改成ignore.

其实如果你没有考虑到兼容性问题时,那就把它关掉吧. 其实有这个功能是好的. 只要任何类别实作了Serializable这个界面,

如果没有加入serialVersionUID,Eclipse都会给你warning提示, 这个serialVersionUID为了让该类别Serializable後兼容.

考虑一下,如果今天你的类Serialized存到硬碟里, 可是後来你却更改了类别的field(增加或减少或改名). 当你Deserialize时,就会出现Exception.

这样就会做成不兼容性的问题.

但当serialVersionUID相同时,它就会将不一样的field以type的预设值Deserialize. 这个可以避开不兼容性的问题.

异常状态: The serializable class XXX does not declare a static final serialVersionUID field of type long

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
package servlet; import db.Database; import module.admin; import javax.servlet.ServletException; import javax.servlet.annotation.WebServlet; import javax.servlet.http.HttpServlet; import javax.servlet.http.HttpServletRequest; import javax.servlet.http.HttpServletResponse; import java.io.IOException; import java.sql.Connection; import java.sql.PreparedStatement; import java.sql.ResultSet; import java.sql.SQLException; import java.util.ArrayList; @WebServlet(name = "viewServlet",urlPatterns = "/view") public class viewServlet extends HttpServlet { private static final long serialVersionUID = 1L; private static final String SQL = "select s_id, password from admin"; // 从连接池获取连接 Connection connection = null; PreparedStatement statement = null; ResultSet resultSet = null; ArrayList<admin> admins = new ArrayList<>(); protected void doPost(HttpServletRequest req, HttpServletResponse resp) throws ServletException, IOException { try { connection = Database.getConnection(); statement = connection.prepareStatement(SQL); resultSet = statement.executeQuery(); System.out.println("连接成功"); while (resultSet.next()) { int s_id = resultSet.getInt("s_id"); String password = resultSet.getString("password"); admin admin = new admin(s_id, password); admins.add(admin); req.setAttribute("message", "数据读取成功"); } req.setAttribute("admins", admins); req.getRequestDispatcher("view.jsp").forward(req, resp); } catch (SQLException e) { e.printStackTrace(); req.setAttribute("message", "操作失败!"); } finally { Database.closeResource(connection, statement, resultSet); } } }
05-31

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值