更新时间:2020-06-02 14:44:10 来源:极悦 浏览1933次
序列化是将对象的状态信息转换为可以储存或者传输的形式的过程。因此在Java开发中,序列化是一个非常重要的环节。Java序列化可以在JVM停止运行之后能够保存(持久化)制定的对象,并在将来重新读取被保存的对象。
使用Java对象序列化,在保存对象时,会把其状态保存为一组字节,在未来,再将这些字节组装成对象。必须注意地是,对象序列化保存的是对象的"状态",即它的成员变量。由此可知,对象序列化不会关注类中的静态变量。
如何序列化
只要一个类实现了java.io.Serializable接口,那么它就可以被序列化。
serialversionuid作用
serialVersionUID适用于Java的序列化机制。简单来说,Java的序列化机制是用判断类的serialVersionUID来验证版本一致性的。在进行反序列化时,JVM会把传来的字节流中的serialVersionUID与本地相应实体类的serialVersionUID进行比较,如果相同就认为是一致的,可以进行反序列化,否则就会出现序列化版本不一致的异常,即是InvalidCastException。
serialversionuid如何产生
在eclipse或者idea中,当实现了Serializable接口以后,在对应行左端会有一个黄色小叹号,点击,选择generaterd serial version ID,就可以生产如图所示的id。
private static final long serialVersionUID=1518830894504324355L;
代码实例
相关知识
1.在Java中,只要一个类实现了java.io.Serializable接口,那么它就可以被序列化。
2.依靠ObjectOutputStream和ObjectInputStream对对象进行序列化及反序列化
3.是否允许反序列化,不仅取决于类路径和功能代码是否一致,一个非常重要的一点是两个类的序列化ID是否一致(就是private static final long serialVersionUID)
4.序列化并不保存静态变量。
5.要想将父类对象也序列化,就需要让父类也实现Serializable接口。
6.Transient关键字的作用是控制变量的序列化,在变量声明前加上该关键字,可以阻止该变量被序列化到文件中,在被反序列化后,transient变量的值被设为初始值,如int型的是0,对象型的是null。
7.服务器端给客户端发送序列化对象数据,对象中有一些数据是敏感的,比如密码字符串等,希望对该密码字段在序列化时,进行加密,而客户端如果拥有解密的密钥,只有在客户端进行反序列化时,才可以对密码进行读取,这样可以一定程度确保序列化对象的数据安全。
以上就是极悦java培训机构的小编针对“Java软件开发教程之Java序列化介绍”的内容进行的回答,希望对大家有所帮助,如有疑问,请在线咨询,有专业老师随时为你服务。
0基础 0学费 15天面授
Java就业班有基础 直达就业
业余时间 高薪转行
Java在职加薪班工作1~3年,加薪神器
工作3~5年,晋升架构
提交申请后,顾问老师会电话与您沟通安排学习