序列化和反序列化概念:

序列化:

把堆内存中的java对象数据,通过某种方式把对象存储到磁盘文件中或者传递给其他网络的节点(在网络上传输)

反序列化:

把磁盘文件中的对象数据或者网络节点上的对象数据,恢复成java对象的过程。


为什么要做序列化:
1):在分布式系统中,需要共享的数据的JavaBean对象,都得做序列化,此时需要把对象再网络上传输,此时就得把对象数据转换为二进制形式.
以后存储在HttpSession中的对象,都应该实现序列化接口(只有实现序列化接口的类,才能做序列化操作).
2):服务钝化:如果服务发现某些对象好久都没有活动了,此时服务器就会把这些内存中的对象,持久化在本地磁盘文件中(Java对象–>二进制文件).
如果某些对象需要活动的时候,现在内存中去寻找,找到就使用,找不到再去磁盘文件中,反序列化我们得对象数据,恢复成Java对象.

需要做序列化的对象的类,必须实现序列化接口:

java.io.Serializable接口(标志接口[没有抽象方法]).

底层会判断,如果当前对象是Serializable的实例,才允许做序列化. boolean ret = Java对象 instanceof Serializable;

在Java中大多数类都已经实现Serializable接口.


使用对象流来完成序列化和反序列化操作:

 ObjectOutputStream:  通过writeObject方法做序列化操作的.ObjectInputStream:     通过readObject方法做反序列化操作的.

注意:

Exception in thread "main" java.io.NotSerializableException: com.test.User表示User类没有实现序列化接口,java.io.Serializable

序列化的细节序列化的版本:
1):如果某些数据不需要做序列化,比如密码,此时怎么办?
理论上说,静态的字段和瞬态的字段是不能做序列化操作的.

transient public String Name;
2):序列化的版本问题反序列化Java对象时必须提供该对象的class文件,现在问题是,随着项目的升级,系统的class文件也会升级(增加一个字段/删除一个字段),如何保证两个class文件的兼容性? Java通过serialVersionUID(序列化版本号)来判断字节码是否发生改变.

如果不显示定义serialVersionUID类变量,该类变量的值由JVM根据类相关信息计算,而修改后的类的计算方式和之前往往不同.
从而造成了对象反序列化因为版本不兼容而失败的问题.

解决方案:在类中提供一个固定的serialVersionUID.

    public static final long serialVersionUID=1L;

练习代码:

package com.test;import java.io.File;
import java.io.FileInputStream;
import java.io.FileNotFoundException;
import java.io.FileOutputStream;
import java.io.IOException;
import java.io.ObjectInput;
import java.io.ObjectInputStream;
import java.io.ObjectOutputStream;
import java.io.Serializable;
class User implements Serializable{public String Name;public int age;public String Sex;public User(String Name, int age, String Sex) {// TODO Auto-generated constructor stubthis.Name=Name;this.age=age;this.Sex=Sex;}
}
public class Main {public static void main(String[] args) throws Exception {File file = new File("file/obj.txt");   writeObject(file);readObject(file);}
//反序列化操作
public static void readObject(File file) throws Exception, Exception {// TODO Auto-generated method stubObjectInputStream stream = new ObjectInputStream(new FileInputStream(file));User user =(User) stream.readObject();System.out.println(user.Name+"-"+user.age+"-"+user.Sex);stream.close();}
//序列化操作public static void writeObject(File file) throws Exception, Exception {// TODO Auto-generated method stubObjectOutputStream stream = new ObjectOutputStream(new FileOutputStream(file));stream.writeObject(new User("DreamZuora",23,"男"));stream.close();}
}

IO对象流(序列化和反序列化)相关推荐

  1. 对象的序列化与反序列化---IO学习笔记(四)

    对象的序列化,反序列化 对象的序列化: 就是将Object转换成byte序列 对象的反序列化: 将byte序列转换成Object 序列化流,反序列化流 序列化流(ObjectOutputStream) ...

  2. Java对象的序列化与反序列化

    序列化与反序列化 序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程.一般将一个对象存储至一个储存媒介,例如文件或是内存缓冲区等.在网络传输过程中,可以是字节或是 ...

  3. java对象的序列化和反序列化详细解释

    java对象的序列化和反序列化是什么意思 1.序列化是干啥用的? 序列化的原本意图是希望对一个Java对象作一下"变换",变成字节序列,这样一来方便持久化存储到磁盘,避免程序运行结 ...

  4. 一文带你全面了解java对象的序列化和反序列化

    本文分享自华为云社区<java中什么是序列化和反序列化?>,原文作者:dayu_dls . 这篇文章主要给大家介绍了关于java中对象的序列化与反序列化的相关内容,文中通过详细示例代码介绍 ...

  5. 反序列化对象列表发生异常_面试官:你知道Java对象的序列化与反序列化背后的原理吗?...

    序列化与反序列化 序列化 (Serialization)是将对象的状态信息转换为可以存储或传输的形式的过程.一般将一个对象存储至一个储存媒介,例如档案或是记亿体缓冲等.在网络传输过程中,可以是字节或是 ...

  6. 装饰设计模式缓冲流转换流序列化与反序列化

    装饰设计模式&缓冲流&转换流&序列化与反序列化 - 能够使用字节缓冲流读取数据到程序1.创建BufferedInputStream对象,构造方法中传递FileInputStre ...

  7. Java对象的序列化和反序列化

    [感谢]孤傲苍狼的 Java基础学习总结--Java对象的序列化和反序列化 一.序列化和反序列化的概念 序列化就是一种用来处理对象流的机制,所谓对象流也就是将对象的内容进行流化.可以对流化后的对象进行 ...

  8. Java IO篇:序列化与反序列化

    1.什么是序列化: 两个服务之间要传输一个数据对象,就需要将对象转换成二进制流,通过网络传输到对方服务,再转换成对象,供服务方法调用.这个编码和解码的过程称之为序列化和反序列化.所以序列化就是把 Ja ...

  9. java中对象的序列化和反序列化

    [对象的序列化和反序列化 ] 1.定义: 序列化--将对象写到一个输出流中.反序列化则是从一个输入流中读取一个对象.类中的成员必须是可序列化的,而且要实现Serializable接口,这样的类的对象才 ...

最新文章

  1. EPICenter: 用户管理
  2. 伯克利论断:Serverless 才是云时代的主宰
  3. python合并两个数据框_python 学习的第五天 数据框合并
  4. React后台管理系统-file-uploader组件
  5. [html] 如何阻止屏幕旋转时自动调整字体的大小?
  6. 苹果耳罩式耳机曝光 将于今年下半年发布
  7. php变量值传递,PHP将值传递到包含文件中的变量
  8. 深度学习自学(二十二):推理框架-MNN
  9. 啊哈C语言 第7章 有了它你能做更多的事(第27-28讲)
  10. 像仓管一样管理redux-仓管也需要才艺(中间件)
  11. 水管工游戏——dfs
  12. 从头构建自己的Linux系统
  13. linux系统怎么连接显示器,Linux下笔记本外接显示器 · Eulerlee
  14. 美国访问学者申请签证存款证明相关事宜
  15. [IT学习]从网上获取pdf制作vce文件
  16. 【youcans 的 OpenCV 例程200篇】129. 形态算法之骨架 (重建开运算)
  17. android 系统的切图方式_android APPUI设计、切图的常用尺寸大全
  18. 蔡楚生暨潮籍电影名人史迹馆在广东汕头开馆
  19. 豆瓣FM-Hacker——豆瓣FM播放列表补全计划
  20. 虚短 虚断 搞定放大器原理计算

热门文章

  1. [前台]---js获取input标签中name相同的各个value值
  2. pc版android sd卡,告别瓶颈:安卓闪存(SD卡)I/O优化
  3. opencv java ubuntu_Ubuntu 16.04配置OpenCV 3.1.0 for Java
  4. 照片识别出错_云投诉丨四川德阳市民文明手册咋满篇乱码?回应:电脑识别问题,已全部收回...
  5. linux php 执行python,Linux(Ubuntu)下php使用exec调用python程序返回json数据
  6. 怎么快速搜索服务器里的文件,使用 Everything,快速搜索电脑文件,制作局域网资料搜索器 | 科技搜...
  7. python3.7.2安装与配置_python3.7.0 安装与配置
  8. java static 修饰变量吗_Java面试 - static 修饰的变量和方法有哪些特点?
  9. matlab 函数 命名参数,如何处理MATLAB中的函数参数的名称/值对
  10. php 强制刷新,web端实现后退强制刷新功能代码