Java中序列化和反序列化解释
在Java中,序列化(Serialization)是指将对象的状态转换为字节流的过程,以便将其保存到文件、在网络中传输或持久化到数据库中。而反序列化(Deserialization)则是将字节流转换回对象的过程,恢复对象的状态。
序列化和反序列化主要用于以下场景:
1. 对象持久化:通过序列化,可以将对象的状态保存到文件或数据库中,以便在程序重新启动后进行恢复。这种持久化的方式可以用于保存应用程序的配置信息、用户数据等。
2. 网络传输:在网络通信中,可以将对象序列化为字节流后进行传输,接收端通过反序列化将字节流恢复为对象。这样可以方便地在分布式系统中传递对象数据。
在Java中,实现序列化和反序列化的关键是通过实现`java.io.Serializable`接口。该接口是一个标记接口,不包含任何方法,只是作为一个标识,表明该类可以被序列化。如果一个类实现了`Serializable`接口,就可以将其对象序列化和反序列化。
序列化的步骤如下:
1. 创建一个输出流(如`FileOutputStream`、`ByteArrayOutputStream`)。
2. 创建一个对象输出流(`ObjectOutputStream`),将输出流传入构造函数。
3. 使用对象输出流的`writeObject()`方法将需要序列化的对象写入输出流。
4. 关闭对象输出流。
反序列化的步骤如下:
1. 创建一个输入流(如`FileInputStream`、`ByteArrayInputStream`),并读取需要反序列化的字节流。
2. 创建一个对象输入流(`ObjectInputStream`),将输入流传入构造函数。
3. 使用对象输入流的`readObject()`方法读取字节流并将其反序列化为对象。
4. 关闭对象输入流。
需要注意的是,要使一个类可序列化,需要满足以下要求:
1. 类必须实现`java.io.Serializable`接口。
2. 类的所有非瞬态(transient)字段都应该是可序列化的,即字段的类型也必须是可序列化的,否则需要将其标记为瞬态。
3. 类的所有父类(直接或间接)都必须是可序列化的。
示例代码如下所示:
1 import java.io.*;
2
3 public class SerializationExample {
4 public static void main(String[] args) {
5 // 序列化对象
6 serializeObject();
7
8 // 反序列化对象
9 deserializeObject();
10 }
11
12 public static void serializeObject() {
13 try {
14 // 创建输出流
15 FileOutputStream fileOut = new FileOutputStream("object.ser");
16 ObjectOutputStream out = new ObjectOutputStream(fileOut);
17
18 // 创建对象并写入输出流
19 MyClass obj = new MyClass("Hello, Serialization!");
20 out.writeObject(obj);
21
22 // 关闭流
23 out.close();
24 fileOut.close();
25
26 System.out.println("对象已成功序列化并保存到文件!");
27 } catch (IOException e) {
28 e.printStackTrace();
29 }
30 }
31
32 public static void deserializeObject() {
33 try {
34 // 创建输入流
35 FileInputStream fileIn = new FileInputStream("object.ser");
36 ObjectInputStream in = new ObjectInputStream(fileIn);
37
38 // 从输入流中读取对象并反序列化
39 MyClass obj = (MyClass) in.readObject();
40
41 // 关闭流
42 in.close();
43 fileIn.close();
44
45 System.out.println("对象已成功反序列化:" + obj.getMessage());
46 } catch (IOException | ClassNotFoundException e) {
47 e.printStackTrace();
48 }
49 }
50 }
51
52 // 需要序列化的类,实现Serializable接口
53 class MyClass implements Serializable {
54 private String message;
55
56 public MyClass(String message) {
57 this.message = message;
58 }
59
60 public String getMessage() {
61 return message;
62 }
63 }
上述示例代码中,`MyClass`类实现了`Serializable`接口,并在`serializeObject()`方法中将`MyClass`对象序列化并保存到文件中。然后在`deserializeObject()`方法中从文件中读取字节流并反序列化为`MyClass`对象。最终输出反序列化后的对象的消息内容。
Java中序列化和反序列化解释的更多相关文章
- Java 中序列化与反序列化
一. 序列化和反序列化概念 Serialization(序列化)是一种将对象以一连串的字节描述的过程:反序列化deserialization是一种将这些字节重建成一个对象的过程.将程序中的对象,放入文 ...
- Java 中序列化与反序列化引发的思考?
java 中序列化指从对象转变为 二进制流的过程中需要进行序列化,而反序列化指二进制流转换为java 对象.那么有的时候java 存储到数据库不需要序列化, 而计算机系统本质存储的就是二进制文件,数据 ...
- JAVA中序列化和反序列化
一般程序在运行时,产生对象,这些对象随着程序的停止运行而消失(java回收机制)但如果我们想把某些对象(因为是对象,所以有各自不同的特性)保存下来,在程序终止运行后,这些对象仍然存在,可以在程序再次运 ...
- JAVA中序列化和反序列化中的静态成员问题
关于这个标题的内容是面试笔试中比较常见的考题,大家跟随我的博客一起来学习下这个过程. ? ? JAVA中的序列化和反序列化主要用于: (1)将对象或者异常等写入文件,通过文件交互传输信息: (2)将对 ...
- java 对象序列化与反序列化
Java序列化与反序列化是什么? 为什么需要序列化与反序列化? 如何实现Java序列化与反序列化? 本文围绕这些问题进行了探讨. 1.Java序列化与反序列化 Java序列化是指把Java对象转换为 ...
- Java对象序列化和反序列化的工具方法
import java.io.File; import java.io.FileInputStream; import java.io.FileNotFoundException; import ja ...
- Java之序列化和反序列化
序列化的对象: package test_demo.SerializableOper; import java.io.Serializable; /* * 序列化对象需要实现序列号接口 * */ pu ...
- Java基础—序列化与反序列化(转载)
转载自: Java序列化与反序列化 1.Java序列化与反序列化 Java序列化是指把Java对象转换为字节序列的过程:而Java反序列化是指把字节序列恢复为Java对象的过程. 2.为什么需要序列化 ...
- Java对象序列化与反序列化一 JSON
Java对象序列化与反序列化一 JSON 1. 依赖库 jackson-all-1.6.1.jar 2. 代码 public class Student { private String nam ...
- java之序列化与反序列化
1.这里主要是介绍Protobuf提供的序列化与反序列化的高效性.相对于传统的java提供的序列化来说,Protobuf的效率提高了很多倍.但是也有不足的地方,就是proto在对象序列化的时候抛弃了很 ...
随机推荐
- SSID、BSSID 和 ESSID辨析
参考 [1] 华为-WLAN常用概念 [2] 了解网络术语 SSID.BSSID 和 ESSID [3] Difference between RSSI and RSS or RSS vs RSSI
- 随机分布和随机数生成——R语言
在人们的生活中,很多场景都需要用到随机数,例如福利彩票,车牌摇号,公共用房分配等.在用数学模型, 包括概率统计模型处理实际应用中的问题时, 我们希望建立的模型能够尽可能地符合实际情况.但是,实际情况是 ...
- 【Diary】CSP-S2 2021 游记 & NOIP 备赛发疯日记
Day 0 两个极端的回跳. .....不行啊. 我快输不起了........... ------------------------------- 早上被生物钟强行唤醒,逼自己懒床到6:40. 弹琴 ...
- Abp框架Web站点的安全性提升
本文将从GB/T 28448-2019<信息安全技术 网络安全等级保护测评要求>规定的安全计算环境中解读.摘要若干安全要求,结合Abp框架,对站点进行安全升级. [身份鉴别]应对登录的用户 ...
- 手把手逐步解析Javaweb登录实例
一.编写前端界面 <!DOCTYPE html> <html lang="en"> <head> <meta charset=" ...
- Hystrix 如何在不引入 Archaius 的前提下实现动态配置更新
Hystrix 简介 Hystrix 是 Netflix 开源的一个限流熔断降级组件,防止依赖服务发生错误后,将调用方的服务拖垮.这里对 Hystrix 本身不做过多介绍. Hystrix 目前处于维 ...
- day05-优惠券秒杀01
功能03-优惠券秒杀01 4.功能03-优惠券秒杀 4.1全局唯一ID 4.1.1全局ID生成器 每个店铺都可以发布优惠券: 当用户抢购时,就会生成订单,并保存到tb_voucher_order这张表 ...
- 2023-05-03:给你一棵 二叉树 的根节点 root ,树中有 n 个节点 每个节点都可以被分配一个从 1 到 n 且互不相同的值 另给你一个长度为 m 的数组 queries 你必须在树上执行
2023-05-03:给你一棵 二叉树 的根节点 root ,树中有 n 个节点 每个节点都可以被分配一个从 1 到 n 且互不相同的值 另给你一个长度为 m 的数组 queries 你必须在树上执行 ...
- 微服务 - Nginx网关 · 进程机制 · 限流熔断 · 性能优化 · 动态负载 · 高可用
系列目录: 微服务 - 概念 · 应用 · 通讯 · 授权 · 跨域 · 限流 微服务 - 集群化 · 服务注册 · 健康检测 · 服务发现 · 负载均衡 微服务 - Redis缓存 · 数据结构 · ...
- Prism Sample 16-RegionContext
终于发现一个有趣的新知识了. 本例的核心是RegionContext,意思是一个区域的上下文.但与DataContext似乎并不相同. 先看一下整体思路. 在主窗体上只有一个Region: <G ...