我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Java序列化和反序列化示例分析

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Java序列化和反序列化示例分析

这期内容当中小编将会给大家带来有关Java序列化和反序列化示例分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。

序列化是为了把Java对象转化为字节序列(字节流)的过程。然后深拷贝是通过对流的操作来实现的,序列化后数据方便存储传输。反序列化则是把字节序列反序列化为Java对象

存储方便:因为对象会被回收,序列化后可以持续化存储在磁盘中
传输方便:字节序列(二进制形式)可以进行网络传输和传播。

最好设置一个SerialversionUID,因为序列化和反序列化是对比SerialversionUID来进行的,虽然不设置接口也会默认生成一个,但是要知道序列化对象过程一般都是对象->序列化->存储或传输->反序列化。
举个例子:
先创建一个实体类Student

import lombok.Data;import java.io.Serializable;@Datapublic class Student implements Serializable {    private Integer id;    private String name;    private String sex;}
然后创建一个测试类SerializableTest
import serialization.entity.Student;import java.io.*;public class SerializableTest {    public static void main(String[] args) throws Exception {        serializeStudent();        Student student = deserializeStudent();        System.out.println("name:" + student.getName());        System.out.println("sex:" + student.getSex());    }    private static void serializeStudent() throws IOException {        Student student = new Student();        student.setId(1);        student.setName("张三");        student.setSex("male");        ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(                new File("F:/student.txt")));        out.writeObject(student);        System.out.println("序列化成功");        out.close();    }    private static Student deserializeStudent() throws Exception {        ObjectInputStream in = new ObjectInputStream(new FileInputStream(new File("F:/student.txt")));        Student student = (Student) in.readObject();        System.out.println("反序列化成功");        return student;    }}
执行结果:
序列化成功反序列化成功name:张三sex:male
这个时候没有指定SerialversionUID也是可以成功的,但对象->序列化->存储或传输->反序列化,咱们在反序列化操作之前对Student类修改呢?

这个时候咱们修改一下代码,先注释掉反序列化代码,先进行序列化。

import serialization.entity.Student;import java.io.*;public class SerializableTest {    public static void main(String[] args) throws Exception {        serializeStudent();//        Student student = deserializeStudent();//        System.out.println("name:" + student.getName());//        System.out.println("sex:" + student.getSex());    }    private static void serializeStudent() throws IOException {        Student student = new Student();        student.setId(1);        student.setName("张三");        student.setSex("male");        ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(                new File("F:/student.txt")));        out.writeObject(student);        System.out.println("序列化成功");        out.close();    }//    private static Student deserializeStudent() throws Exception {//        ObjectInputStream in = new ObjectInputStream(new FileInputStream(new File("F:/student.txt")));//        Student student = (Student) in.readObject();//        System.out.println("反序列化成功");//        return student;//    }}
运行结果:
序列化成功

修改Student类

import lombok.Data;import java.io.Serializable;@Datapublic class Student implements Serializable {    private Integer id;    private String name;    private String sex;    private String address;}
注释掉序列化方法,进行反序列化
import serialization.entity.Student;import java.io.*;public class SerializableTest {    public static void main(String[] args) throws Exception {//        serializeStudent();        Student student = deserializeStudent();        System.out.println("name:" + student.getName());        System.out.println("sex:" + student.getSex());    }//    private static void serializeStudent() throws IOException {//        Student student = new Student();//        student.setId(1);//        student.setName("张三");//        student.setSex("male");////        ObjectOutputStream out = new ObjectOutputStream(new FileOutputStream(//                new File("F:/student.txt")));//        out.writeObject(student);//        System.out.println("序列化成功");//        out.close();//    }    private static Student deserializeStudent() throws Exception {        ObjectInputStream in = new ObjectInputStream(new FileInputStream(new File("F:/student.txt")));        Student student = (Student) in.readObject();        System.out.println("反序列化成功");        return student;    }}
执行结果:
Exception in thread "main" java.io.InvalidClassException: serialization.entity.Student; local class incompatible: stream classdesc serialVersionUID = 3846952599709361171, local class serialVersionUID = -4606152942663467236at java.io.ObjectStreamClass.initNonProxy(ObjectStreamClass.java:699)at java.io.ObjectInputStream.readNonProxyDesc(ObjectInputStream.java:1885)at java.io.ObjectInputStream.readClassDesc(ObjectInputStream.java:1751)at java.io.ObjectInputStream.readOrdinaryObject(ObjectInputStream.java:2042)at java.io.ObjectInputStream.readObject0(ObjectInputStream.java:1573)at java.io.ObjectInputStream.readObject(ObjectInputStream.java:431)at serialization.demo.SerializableTest.deserializeStudent(SerializableTest.java:30)at serialization.demo.SerializableTest.main(SerializableTest.java:10)Process finished with exit code 1
可以看出两次的执行的SerialversionUID不匹配,导致产生java.io.InvalidClassException异常,所以只要指定了SerialversionUID就不会报异常。
//指定serialVersionUID正确写法private static final long serialVersionUID = 3846952599709361171L;//如果已经进行序列化了不知道SerialversionUID,可以通过反射获取Object obj = Student.class.newInstance();Field field = Student.class.getDeclaredField("serialVersionUID");field.setAccessible(true);System.out.println(field.getLong(obj));

最后需要知道的一点就是字节流字符流的区别。
字节流:传输过程中,传输数据的最基本单位是字节的流。
字符流:传输过程中,传输数据的最基本单位是字符的流。

这样讲可能有点不知所云,字节其实就是Java的八大基本类型Byte(比特)单位,而字符通常是’A’、‘B’、’$’、’&'等,字节大小则取决于你是什么编码(环境),如下:

ASCII 码中,一个英文字母(不分大小写)为一个字节,一个中文汉字为两个字节。

UTF-8 编码中,一个英文字为一个字节,一个中文为三个字节。

Unicode 编码中,一个英文为一个字节,一个中文为两个字节。

符号:英文标点为一个字节,中文标点为两个字节。例如:英文句号 . 占1个字节的大小,中文句号 。

占2个字节的大小。UTF-16 编码中,一个英文字母字符或一个汉字字符存储都需要 2 个字节(Unicode 扩展区的一些汉字存储需要 4 个字节)。

UTF-32 编码中,世界上任何字符的存储都需要 4 个字节。

上述就是小编为大家分享的Java序列化和反序列化示例分析了,如果刚好有类似的疑惑,不妨参照上述分析进行理解。如果想知道更多相关知识,欢迎关注编程网行业资讯频道。

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Java序列化和反序列化示例分析

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

Java序列化和反序列化示例分析

这期内容当中小编将会给大家带来有关Java序列化和反序列化示例分析,文章内容丰富且以专业的角度为大家分析和叙述,阅读完这篇文章希望大家可以有所收获。序列化是为了把Java对象转化为字节序列(字节流)的过程。然后深拷贝是通过对流的操作来实现的
2023-06-26

Java中序列化与反序列化的示例分析

这篇文章将为大家详细讲解有关Java中序列化与反序列化的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。一、前言序列化:将对象转换为二进制序列在网络中传输或保存到磁盘反序列化:从网络或磁盘中将二进制
2023-06-15

Java对象的序列化和反序列化举例分析

本篇内容介绍了“Java对象的序列化和反序列化举例分析”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!1、什么是序列化与反序列化?  序列化:
2023-06-19

Python中序列化与反序列化的示例分析

这篇文章将为大家详细讲解有关Python中序列化与反序列化的示例分析,小编觉得挺实用的,因此分享给大家做个参考,希望大家阅读完这篇文章后可以有所收获。初识序列化与反序列化什么是序列化?通俗一点来说,序列化就是将 对象的信息 或者 数据结构的
2023-06-29

Python反序列化的示例分析

这篇文章给大家分享的是有关Python反序列化的示例分析的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。Python反序列化漏洞Pickle序列化:pickle.dumps() 将对象序列化为字符串、pickle.
2023-06-29

Ezpop pop序列化链反序列化实例分析

这篇文章主要介绍了Ezpop pop序列化链反序列化实例分析的相关知识,内容详细易懂,操作简单快捷,具有一定借鉴价值,相信大家阅读完这篇Ezpop pop序列化链反序列化实例分析文章都会有所收获,下面我们一起来看看吧。
2023-06-30

Java序列化与反序列化

这篇文章主要介绍了Java的序列化与反序列化,序列化把一个对象JavaObject变为一个二进制字节序列byte[];反序列化就是把一个二进制字节序列byte[]变为Java对象JavaObject。感兴趣的小伙伴可以参考阅读
2023-05-14

Kryo序列化及反序列化用法示例

Kryo 是一个快速高效的 Java 对象图形序列化框架,主要特点是性能、高效和易用。该项目用来序列化对象到文件、数据库或者网络。 代码地址:https://github.com/EsotericSoftware/kryo 样例
2023-05-31

PHP中session反序列化的示例分析

小编给大家分享一下PHP中session反序列化的示例分析,希望大家阅读完这篇文章之后都有所收获,下面让我们一起去探讨吧!session反序列化的漏洞是由三种不同的反序列化引擎所产生的的漏洞其中session.serialize_handl
2023-06-29

Java之对象的序列化和反序列化

对象的序列化和反序列化1)对象序列化,就是将Object对象转换成byte序列,反之叫对象的反序列化。2)序列化流(ObjectOutputStream),是字节的过滤流—— writeObject()方法 反序列化流(ObjectInputStrea
Java之对象的序列化和反序列化
2019-09-29

Java对象的XML序列化与反序列化实例解析

上一篇文章我们介绍了java实现的各种排序算法代码示例,本文我们看看Java对象的xml序列化与反序列化的相关内容,具体如下。XML是一种标准的数据交换规范,可以方便地用于在应用之间交换各类数据。如果能在Java对象和XML文档之间建立某种
2023-05-30

MessagePack和System.Text.Json序列化和反序列化性能及对比分析

这篇文章主要介绍了MessagePack和System.Text.Json序列化和反序列化性能及对比分析,本文结合示例代码给大家介绍的非常详细,需要的朋友可以参考下
2023-01-28

MessagePack 和System.Text.Json 序列化和反序列化性能及对比分析

MessagePack和System.Text.Json是.NET生态系统中常用的序列化和反序列化库。性能对比:序列化:MessagePack通常比System.Text.Json更快,因为它使用二进制格式并无需将数据转换为中间表示形式。反序列化:MessagePack也通常比System.Text.Json更快,因为它直接将二进制数据转换为对象。其他考虑因素:大小:MessagePack产生的二进制数据比System.Text.Json的JSON字符串更小。可读性:JSON字符串比二进制数据更具可读性。
MessagePack 和System.Text.Json 序列化和反序列化性能及对比分析
2024-04-02

编程热搜

  • Python 学习之路 - Python
    一、安装Python34Windows在Python官网(https://www.python.org/downloads/)下载安装包并安装。Python的默认安装路径是:C:\Python34配置环境变量:【右键计算机】--》【属性】-
    Python 学习之路 - Python
  • chatgpt的中文全称是什么
    chatgpt的中文全称是生成型预训练变换模型。ChatGPT是什么ChatGPT是美国人工智能研究实验室OpenAI开发的一种全新聊天机器人模型,它能够通过学习和理解人类的语言来进行对话,还能根据聊天的上下文进行互动,并协助人类完成一系列
    chatgpt的中文全称是什么
  • C/C++中extern函数使用详解
  • C/C++可变参数的使用
    可变参数的使用方法远远不止以下几种,不过在C,C++中使用可变参数时要小心,在使用printf()等函数时传入的参数个数一定不能比前面的格式化字符串中的’%’符号个数少,否则会产生访问越界,运气不好的话还会导致程序崩溃
    C/C++可变参数的使用
  • css样式文件该放在哪里
  • php中数组下标必须是连续的吗
  • Python 3 教程
    Python 3 教程 Python 的 3.0 版本,常被称为 Python 3000,或简称 Py3k。相对于 Python 的早期版本,这是一个较大的升级。为了不带入过多的累赘,Python 3.0 在设计的时候没有考虑向下兼容。 Python
    Python 3 教程
  • Python pip包管理
    一、前言    在Python中, 安装第三方模块是通过 setuptools 这个工具完成的。 Python有两个封装了 setuptools的包管理工具: easy_install  和  pip , 目前官方推荐使用 pip。    
    Python pip包管理
  • ubuntu如何重新编译内核
  • 改善Java代码之慎用java动态编译

目录