java基础 序列化

参考文档:
序列化与反序列化:http://kb.cnblogs.com/page/515982/
jdk中的序列化api:http://blog.csdn.net/abc6368765/article/details/51365838
jdk中如何序列化:http://www.cnblogs.com/redcreen/articles/1955307.html

什么是序列化&为什么要序列化
序列化 (Serialization)将对象的状态信息转换为可以存储或传输的形式的过程。在序列化期间,对象将其当前状态写入到临时或持久性存储区。以后,可以通过从存储区中读取或反序列化对象的状态,重新创建该对象

主流序列化框架

按照序列化后的数据格式,主流的序列化框架主要可以分为四大类:
JSON类

非常流行的Jackson
Google的Gson。 Gson是目前功能最全的Json解析神器,无依赖,直接跑在jdk上。性能稍逊于fastjson
类JSON的MessagePack
阿里的FastJSON。性能最好。无依赖,不需要例外额外的jar,能够直接跑在JDK上

二进制类

老牌劲旅Hessian(以前很喜欢用的)
功能全面而强大的FST
后起之秀Kryo

XML类

StAX(Streaming API for XML)
Thoughwork的XStream

RPC类(都要安装、编译)

Protobuf
Thrift
Apache Avro

判断一个编码框架的优劣主要从以下几个方面

  1. 是否支持跨语言,支持语种是否丰富
  2. 编码后的码流存储空间
  3. 编解码的性能
  4. 类库是否小巧,API使用是否方便

java序列化的缺点

  1. 无法跨语言。这应该是java序列化最致命的问题了。由于java序列化是java内部私有的协议,其他语言不支持,导致别的语言无法反序列化,这严重阻碍了它的应用
  2. 序列后的码流太大。java序列化的大小是二进制编码的5倍多
  3. 序列化性能太低。java序列化的性能只有二进制编码的6.17倍

jdk类库中的序列化api

序列化的实现

只有实现了SerializableExternalizable接口的类的对象才能被序列化。Externalizable接口继承自Serializable接口,实现Externalizable接口的类完全由自身来控制序列化的行为,而仅实现Serializable接口的类可以采用默认的序列化方式
ObjectOutputStream代表对象输出流,它的writeObject(Object obj)方法可对参数指定的obj对象进行序列化,把得到的字节序列写到一个目标输出流中
ObjectInputStream代表对象输入流,它的readObject()方法从一个源输入流中读取字节序列,再把它们反序列化为一个对象,并将其返回

serialVersionUID的作用

s?e?r?i?a?l?V?e?r?s?i?o?n?U?I?D?:? ?字?面?意?思?上?是?序?列?化?的?版?本?号?,凡是实现Serializable接口的类都有一个表示序列化版本标识符的静态变量
serialVersionUID有两种生成方式:

serialVersionUID是1L
private static final long serialVersionUID = 1L;
在可兼容的前提下,可以保留旧版本号,如果不兼容,或者想让它不兼容,就手工递增版本号。

serialVersionUID是依据类名,接口名,方法和属性等来生成的hash值:
private static final long serialVersionUID = 4603642343377807741L;
是根据类的结构产生的hash值。增减一个属性、方法等,都可能导致这个值产生变化。我想这种方式适用于这样的场景:开发者认为每次修改类后就需要生成新的版本号,不想向下兼容,操作就是删除原有serialVesionUid声明语句,再自动生成一下

举例:
User类序列到到kafka中,如果不指定serialVersionUID,该user类新增加了一个age属性,在反序列化的时候,则会抛出异常,拒绝载入。是因为改动user类以后,生成了一个新的serialVersionUID,与存储在kafka中的已经序列化的serialVersionUID版本不一致。所以反序列化发生冲突

静态变量序列化

序列化保存的是对象的状态,静态变量属于类的状态,因此序列化并不保存静态变量

父类的序列化

父类实现接口后,所有派生类的属性都会被序列化。子类实现接口的话,父类的属性值丢失

Transient关键字

Transient关键字的作用是控制变量的序列话,在变量声明前加上该关键字,可以阻止该变量被序列化到文件中,在被反序列化后,transient 变量的值被设为初始值,如 int 型的是 0,对象型的是 null

原文地址:https://www.cnblogs.com/amei0/p/8480260.html

时间: 2024-10-09 22:39:38

java基础 序列化的相关文章

Java基础——序列化

Java的“对象序列化”能将一个实现了Serialiable接口(标记接口,没有任何方法)的对象转化为一组byte,这样日后要用到这个对象的时候,就能把这些byte数据恢复出来,并据此重新构建那个对象.这一点在跨网络的环境下也是如此,这就意味着序列化机制能自动补偿操作系统方面的差异.也就是说,可以在Windows机器上创建一个对象,序列化之后,再通过网络传到UNIX机器上,最后再那里重建该对象,不用担心在不同平台上数据是怎么表示的,以及byte顺序怎么样,或者 别的什么细节. 要想序列化对象,必

一天一个Java基础——序列化

1.概念 Java的“对象序列化”能将一个实现了Serializable接口的对象转换成一组byte,这样日后要用这个对象的时候,能把这些byte数据恢复出来,并据此重新构建那个对象. 对象序列化能实现“轻量级persistence(lightweight persistence)”.所谓persistence,是指对象的生命周期不是由程序是否运行决定的,在程序的两次调用之间对象仍然还活着.通过“将做过序列化处理的对象写入磁盘,等到程序再次运行的时候再把它读出来”,可以达到persistence

【Java基础】序列化与反序列化深入分析

一.前言 复习Java基础知识点的序列化与反序列化过程,整理了如下学习笔记. 二.为什么需要序列化与反序列化 程序运行时,只要需要,对象可以一直存在,并且我们可以随时访问对象的一些状态信息,如果程序终止,那么对象是肯定不会存在的,但是有时候,我们需要再程序终止时保存对象的状态信息,之后程序再次运行时可以重新恢复到之前的状态,如,玩家玩游戏退出时,需要保存玩家的状态信息(如等级.装备等等),之后玩家再此登入时,必须要恢复这些状态信息.我们可以通过数据库手段来达到这个保存状态的目的,在Java中,我

Java基础学习总结——Java对象的序列化和反序列化

一.序列化和反序列化的概念 把对象转换为字节序列的过程称为对象的序列化. 把字节序列恢复为对象的过程称为对象的反序列化. 对象的序列化主要有两种用途: 1) 把对象的字节序列永久地保存到硬盘上,通常存放在一个文件中: 2) 在网络上传送对象的字节序列. 在很多应用中,需要对某些对象进行序列化,让它们离开内存空间,入住物理硬盘,以便长期保存.比如最常见的是Web服务器中的Session对象,当有 10万用户并发访问,就有可能出现10万个Session对象,内存可能吃不消,于是Web容器就会把一些s

Java基础之序列化详解

相关定义及用途 java序列化(又叫串行化)技术可以使你将一个对象的状态写入一个Byte流里,并且可以从其他地方把该Byte流里的数据读出来,重新构造一个相同的对象.这种机制允许你将对象通过网络进行传播,并可以随时把对象持久化到数据库.文件等系统里.java的序列化机制是RMI(远程方法调用).EFB等技术的技术基础. 用途:利用对象的序列化实现保存应用程序的当前工作状态,下次再启动的是时候将自动恢复到上次执行的状态. 序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化.可

Java基础之对象序列化

1. 什么是Java对象序列化 Java平台允许我们在内存中创建可复用的Java对象,但一般情况下,只有当JVM处于运行时,这些对象才可能存在,即,这些对象的生命周期不会比JVM的生命周期更长.但在现实应用中,就可能要求在JVM停止运行之后能够保存(持久化)指定的对象,并在将来重新读取被保存的对象.Java对象序列化就能够帮助我们实现该功能. 使用Java对象序列化,在保存对象时,会把其状态保存为一组字节,在未来,再将这些字节组装成对象.必须注意地是,对象序列化保存的是对象的"状态",

Java基础 (12) - 序列化

1.序列化是干什么的?内存中的各种对象的状态(也就是实例变量,不是方法),并且可以把保存的对象状态再读出来. 2.什么情况下序列化a.对象需要持久化 (硬盘or数据库)??? b.网络传输 (套接字orRMI)c.在进程间传递对象 3.序列化ID的作用java的序列化机制是通过在运行时判断类的serialVersionUID来验证版本一致性的.反序列化时,JVM会把传来的字节流中的serialVersionUID与本地实体类中的serialVersionUID进行比较,如果相同则认为是一致的,便

夯实Java基础系列22:一文读懂Java序列化和反序列化

本系列文章将整理到我在GitHub上的<Java面试指南>仓库,更多精彩内容请到我的仓库里查看 https://github.com/h2pl/Java-Tutorial 喜欢的话麻烦点下Star哈 文章首发于我的个人博客: www.how2playlife.com 本文参考 http://www.importnew.com/17964.html和 https://www.ibm.com/developerworks/cn/java/j-lo-serial/ 序列化与反序列化概念 序列化 (S

第3篇-JAVA基础

第3篇-JAVA基础 每篇一句 :目标是给梦想一个期限,行动与坚持就是实现梦想的过程 初学心得: 遇到困难或问题,它不是休止符,而是引向你如何解决问题的标识 (笔者:JEEP/711)[JAVA笔记 | 时间:2017-03-26| JAVA基础 Ⅱ] 上篇回顾 上篇文章中我们学习了JAVA底层的运行机制与深入剖析以及解释其中JAVA基础代码的含义 本篇文章将JAVA基础Ⅱ全面剖析解释,因为JAVA基础非常重要,务必要牢记知识点!!! 1.JAVA基础语法格式 JAVA采用unicode编码 1