java基础--序列化与反序列化的概念是什么?

经典总结

序列化就是把Java对象变成一串字节流,字节流就像是一种“通用语言”,可以在不同的计算机间传递。 这样做的主要目的是保存对象的状态,以便以后可以恢复。

反序列化则是把这些字节流重新变回Java对象, 恢复对象的状态,方便程序继续使用它。

详情内容

1. 什么是序列化?

序列化是将Java对象转换为字节流的过程。字节流是一个平台无关的格式,可以在不同的计算机系统间传输。序列化的主要目的是将对象的状态保存下来,以便后续恢复。

为什么要使用序列化

  • 跨网络传输:通过网络传输对象,使得分布式系统中的不同节点能够相互通信。
  • 远程方法调用:在远程方法调用(如RMI)中传递对象。

如何实现序列化

Java通过实现Serializable接口来支持序列化。该接口是一个标记接口,不包含任何方法。当类实现了Serializable接口时,它的对象就可以被序列化。

代码示例

import java.io.*;public class Person implements Serializable {private String name;private int age;// 构造函数public Person(String name, int age) {this.name = name;this.age = age;}// 重写toString方法@Overridepublic String toString() {return "Person{name='" + name + "', age=" + age + "}";}public static void main(String[] args) throws IOException {Person person = new Person("Alice", 30);// 序列化:将对象转换为字节流并保存到文件try (ObjectOutputStream oos = new ObjectOutputStream(new FileOutputStream("person.ser"))) {oos.writeObject(person);System.out.println("Object has been serialized.");}}
}

在这个例子中,Person类实现了Serializable接口,因此person对象可以被序列化并保存到名为person.ser的文件中。

2. 什么是反序列化?

反序列化是将字节流转换回Java对象的过程。反序列化的目标是恢复之前序列化的对象,使其能够在应用程序中重新使用。反序列化需要确保字节流的内容与对象结构一致。

反序列化的应用场景

  • 读取存储的数据:从文件或数据库中读取字节流并转换回对象。
  • 接收网络传输的对象:从网络中接收字节流并恢复成对象,在分布式应用中非常常见。

如何实现反序列化

反序列化通过ObjectInputStream类实现。readObject()方法将字节流转换回Java对象。反序列化时,Java会根据字节流中的数据恢复对象的状态。

代码示例

import java.io.*;public class DeserializePerson {public static void main(String[] args) throws IOException, ClassNotFoundException {// 反序列化:从字节流中恢复对象try (ObjectInputStream ois = new ObjectInputStream(new FileInputStream("person.ser"))) {Person person = (Person) ois.readObject();System.out.println("Object has been deserialized: " + person);}}
}

在这个例子中,DeserializePerson类从person.ser文件中读取字节流并反序列化成一个Person对象。注意,我们需要进行类型转换,将读取的对象转换为Person类型。

3. 序列化与反序列化的应用场景

  • 缓存存储:可以将对象序列化后存储在缓存中,反序列化时快速恢复对象。比如使用Redis存储对象时,可以将对象序列化成字节流存储在Redis中,读取时再反序列化回来。
  • 消息队列:在消息中间件(如Kafka、RabbitMQ等)中,消息通常是对象的序列化形式。消息消费者通过反序列化来获取消息内容。
  • 网络通信:在远程调用过程中,客户端和服务端需要通过序列化和反序列化来交换对象数据,尤其在分布式系统中尤为重要。

4. 序列化的安全性和优化

虽然序列化在很多场景中非常有用,但它也可能带来一些问题和挑战,特别是在安全性性能方面。

1. 安全性

  • 反序列化漏洞:恶意用户可能构造恶意的字节流,利用反序列化漏洞进行攻击(如远程代码执行)。为了防止这种情况,不信任的数据应该避免反序列化。
  • 类版本不匹配:如果序列化和反序列化过程中类的结构发生变化(例如字段的增加或删除),可能导致反序列化失败。可以通过**serialVersionUID**来解决这个问题,确保类版本一致性。

代码示例:添加serialVersionUID

public class Person implements Serializable {private static final long serialVersionUID = 1L;private String name;private int age;// 构造函数和toString方法略
}

2. 性能优化

  • transient关键字:如果类中的某个字段不需要序列化,可以使用transient关键字标记该字段。这样在序列化时,transient字段的值将不会被保存。

代码示例:使用transient关键字

public class Person implements Serializable {private String name;private transient int age;  // 不需要序列化的字段// 构造函数和toString方法略
}
  • 对象池与自定义序列化机制:对于频繁序列化和反序列化的对象,使用对象池可以减少创建和销毁对象的性能开销。此外,自定义序列化可以更细粒度地控制序列化过程,避免不必要的数据传输。

知识拓展

1. 序列化与JSON、XML的比较

虽然Java的序列化机制非常方便,但在跨语言和平台的应用中,JSONXML常常被用作数据交换格式。与Java原生的序列化相比,JSON和XML更加轻量级跨平台,可以被多种编程语言解析。

  • JSON:简洁、易于理解和使用,广泛应用于Web API和微服务架构中。
  • XML:比JSON冗长,但在复杂的数据结构和传统的Web服务中仍然广泛应用。

Java中使用Jackson库可以轻松实现JSON序列化和反序列化。

import com.fasterxml.jackson.databind.ObjectMapper;public class JsonExample {public static void main(String[] args) throws Exception {Person person = new Person("Alice", 30);ObjectMapper objectMapper = new ObjectMapper();// 序列化:Java对象转JSONString json = objectMapper.writeValueAsString(person);System.out.println("Serialized JSON: " + json);// 反序列化:JSON转Java对象Person deserializedPerson = objectMapper.readValue(json, Person.class);System.out.println("Deserialized Person: " + deserializedPerson);}
}
2. Apache Avro 与序列化

对于大规模分布式系统,Apache Avro是另一种流行的序列化框架。它支持更高效的序列化和反序列化,尤其是在处理结构化数据时。

  • 优势:Avro比传统的Java序列化更加高效,支持压缩,并且具有良好的跨语言支持。在Apache Kafka和大数据系统中,Avro常用于数据传输和存储。

Java代码示例:使用JSON与Jackson进行序列化和反序列化

import com.fasterxml.jackson.databind.ObjectMapper;public class JacksonExample {public static void main(String[] args) throws Exception {Person person = new Person("Bob", 25);ObjectMapper objectMapper = new ObjectMapper();// 序列化为JSON字符串String json = objectMapper.writeValueAsString(person);System.out.println("Serialized JSON: " + json);// 从JSON字符串反序列化回对象Person deserializedPerson = objectMapper.readValue(json, Person.class);System.out.println("Deserialized Person: " + deserializedPerson);}
}

总结

Java的序列化与反序列化为我们提供了方便的数据持久化和传输机制,尤其在分布式系统和大数据应用中具有广泛的应用场景。

尽管它非常强大,但也需要注意安全性和性能问题。使用适当的序列化技术,并结合**transient关键字和serialVersionUID**等机制,可以使得序列化过程更加高效和安全。

同时,JSONAvro等其他序列化框架在某些场景下也能提供更好的性能和跨平台支持。通过理解并合理使用这些技术,开发者可以实现更高效、更安全的数据交换与存储。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/37522.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

【AI Infra】【RLHF框架】二、VeRL中colocate实现解析

​ colocate的作用是使多个Worker共享相同的资源池。当然,目前verl中所有模型的Worker都共享相同的资源池:global_pool。这篇博客主要通过例子和源代码理解verl中colocate的实现,需要一些前置知识。建议先阅读 【AI Infra】【RLHF框架】一、VeRL中基于R…

PostgreSQL_数据表结构设计并创建

目录 前置: 1 数据表设计思路 2 数据表格SQL 3 创建 3.1 创建数据库 db_stock 3.2 在 pgAdmin4 中创建表 前置: 本博文是一个系列。在本人“数据库专栏”-》“PostgreSQL_”开头的博文 1 数据表设计思路 1 日数据来自优矿,优矿的数据…

植物来源药用天然产物的合成生物学研究进展-文献精读121

植物来源药用天然产物的合成生物学研究进展 摘要 大多数药用天然产物在植物中含量低微,提取分离困难;而且这些化合物一般结构复杂,化学合成难度大,还容易造成环境污染。基于合成生物学技术获得药用天然产物具有绿色环保和可持续发…

Nordic nRF 蓝牙的 Direct Test Mode (DTM) 测试介绍

目录 概述 1. 核心物理层参数 1.1 射频频率 (RF Channel Frequency) 1.2 发射功率 (TX Power) 1.3 调制方式 (Modulation) 1.4 数据包类型 (Packet Type) 1.5 测试模式 (Test Mode) 2. 参数配置方法 2.1 通过 HCI 命令配置 2.2 示例(nRF52 系列&#xff0…

区间震荡指标

区间震荡指标的逻辑如下: 一、函数注解 1. Summation函数 功能: 计算给定价格序列Price的前Length个数据点的和,或在数据点数量超过Length时,计算滚动窗口内的价格和。 参数: Price(1):价格序列&#…

文章防洗稿隐蔽混淆软件

如果你的文章经常被人洗稿搬运,那么这个小工具或许可以帮到你 基本原理: 在文章的每个字后面,加上一些随机的隐藏字符 人眼看不到,但是机器会读取到,如果别人是用AI工具来对你的文章进行洗稿,就会发现这是一堆乱码 你…

车载软件架构 --- AUTOSAR AP/CP中诊断的区别

我是穿拖鞋的汉子,魔都中坚持长期主义的汽车电子工程师。 老规矩,分享一段喜欢的文字,避免自己成为高知识低文化的工程师: 周末洗了一个澡,换了一身衣服,出了门却不知道去哪儿,不知道去找谁&am…

百度OCR调用记录

根据说明,调用测试 设置注册的API Key和Secret Key 调用类(官方文档中有) 这里改传入路径; 测试问题 1.{"error_code":110,"error_msg":"Access token invalid or no longer valid"} 查到说是 …

19.哈希表的实现

1.哈希的概念 哈希(hash)⼜称散列,是⼀种组织数据的⽅式。从译名来看,有散乱排列的意思。本质就是通过哈希函数把关键字Key跟存储位置建⽴⼀个映射关系,查找时通过这个哈希函数计算出Key存储的位置,进⾏快速查找。 1.2.直接定址法…

网络编程之解除udp判断客户端是否断开

思路&#xff1a;每几秒发送一条不显示的信息&#xff0c;客户端断开则不再发送信息&#xff0c;超时则表示客户端断开连接。&#xff08;心跳包&#xff09; 服务器 #include <head.h>#define MAX_CLIENTS 100 // 最大支持100个客户端 #define TIMEOUT 5 // 5秒…

Java 大视界 -- Java 大数据在智能医疗远程会诊与专家协作中的技术支持(146)

&#x1f496;亲爱的朋友们&#xff0c;热烈欢迎来到 青云交的博客&#xff01;能与诸位在此相逢&#xff0c;我倍感荣幸。在这飞速更迭的时代&#xff0c;我们都渴望一方心灵净土&#xff0c;而 我的博客 正是这样温暖的所在。这里为你呈上趣味与实用兼具的知识&#xff0c;也…

调用feapder作为子程序时setting.py文件不起作用

feaper 官方文档地址&#xff1a; 简介及安装 - feapder官方文档|feapder-document 问题&#xff1a; 在最近的开发中需要调用feapder作为主程序调用的子程序时发现自动入库时无法入库&#xff0c;通过查看日志信息发现连接数据库时被拒绝连接了&#xff0c;但是我的setting.p…

【STM32】SPI通信协议W25Q64Flash存储器芯片(学习笔记)

通信接口部分有介绍SPI&#xff1a;【STM32】USART串口协议&串口外设-学习笔记-CSDN博客 SPI通信协议 SPI通信 SPI&#xff08;Serial Peripheral Interface&#xff09;是由Motorola公司开发的一种通用数据总线四根通信线&#xff1a;SCK&#xff08;Serial Clock&…

刘强东突然发声:不该用算法压榨最底层兄弟!东哥,真正的人民企业家

今天忙了一天&#xff0c;很累&#xff0c;准备睡觉的时候&#xff0c;看到网上盛传的刘强东的朋友圈&#xff0c;东哥又在朋友圈发文了。 说实话&#xff0c;看完之后&#xff0c;感动&#xff0c;真的感动。 尤其是当我看到这两句话的时候。 1、我们所学的知识、商业模式、技…

Maven安装与环境配置

首先我们先介绍一些关于Maven的知识&#xff0c;如果着急直接看下面的安装教程。 目录 Maven介绍 Maven模型 Maven仓库 Maven安装 下载 安装步骤 Maven介绍 Apache Maven是一个项目管理和构建工具&#xff0c;它基于项目对象模型(Project Object Model , 简称: POM)的概念…

C++ 语法之数组指针

一维数组&#xff1a; 如果我们定义了一个一维数组&#xff0c;那么这个数组名&#xff0c;就是指向第一个数组元素的地址&#xff0c;也即&#xff0c;是整个数组分配的内存空间的首地址。 比如 int a[3]; 定义了一个包含三个元素的数组。因为一个int占4个字节&#xff0c;那…

021-TCMalloc

TCMalloc 以下是对TCMalloc的技术调研报告&#xff0c;结合原理、代码实现、优化参数及性能对比的综合分析&#xff1a; 一、TCMalloc核心原理 架构分层 TCMalloc采用三级缓存结构&#xff0c;具体流程参考下图&#xff1a; ┌─────────────┐ ┌───…

华为网路设备学习-16 虚拟路由器冗余协议(VRRP)

VRRP是针对干线上三层网络设备&#xff08;如&#xff1a;路由器、防火墙等&#xff09;的网络虚拟化技术&#xff0c;提供冗余和状态监测等功能。确保在网络中的单点故障发生时&#xff0c;能够快速切换到备份设备&#xff0c;从而保证网络通信的连续性和可靠性。‌ VRRP通过…

【华为Pura先锋盛典】华为Pura X“阔折叠”手机发布:首次全面搭载HarmonyOS 5

文章目录 前言一、阔感体验&#xff0c;大有不同二、鸿蒙AI&#xff0c;大有智慧三、便携出行&#xff0c;大有不同四、首款全面搭载 HarmonyOS 5 的手机五、卓越性能&#xff0c;可靠安心六、红枫影像&#xff0c;大放光彩预热&#xff1a;鸿蒙电脑HarmonyOS 5 升级计划小结 前…

算法题(103):数独

审题&#xff1a; 本题需要我们找出数独的解&#xff0c;并打印出来 时间复杂度分析&#xff1a; 本题是9*9的数独格子&#xff0c;所以数据量小于25&#xff0c;可以使用2^n的算法 思路&#xff1a; 方法一&#xff1a;深度优先搜索 首先确定搜索及插入策略&#xff1a; 我们采…