本篇内容介绍了“java序列化的知识点介绍”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
创新互联专注于宜州网站建设服务及定制,我们拥有丰富的企业做网站经验。 热诚为您提供宜州营销型网站建设,宜州网站制作、宜州网页设计、宜州网站官网定制、成都微信小程序服务,打造宜州网络公司原创品牌,更为您提供宜州网站排名全网营销落地服务。
序列化是将对象的状态信息转换为可以储存或者传输的形式的过程。因此在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序列化的知识点介绍
当前URL:http://lswzjz.com/article/jgsjes.html