序列化和反序列化

概念

序列化,是指将对象(或数据结构)转换成一种可传输、可保存的格式的过程。这种格式通常是与平台无关的【**跨平台】**字节流(如Json、二进制、XML等)。

反序列化,即是将被序列化的文件还原成原对象(或数据结构)的过程。

优势

相较于一般直接将对象存在磁盘相比,主要有以下几点优势:

安全性

若将对象直接保存到磁盘,其他人在查看磁盘中的文件时能轻易知道保存的内容,甚至可以直接篡改数据,有很大的风险。

而通过序列化将对象保存到磁盘,可以进行简单的加密(Json、二进制或XML加密),使其他人不了解保存的数据信息,而且在篡改数据后,反序列化很可能会直接失败使程序员能迅速察觉到风险。

跨平台

将对象转换为平台无关的格式(如 JSON、XML、Protobuf、二进制流等),支持不同操作系统、编程语言之间的数据交换。

而直接写入内存二进制数据,依赖特定平台的内存布局(如字节序、对齐方式),无法跨语言或跨平台使用。

封装性

直接存储中,若要存储多个对象,就要创建多个文件,读取时提取相应文件即可。

而使用序列化,会将多个对象数据整合起来,转换成流存放在磁盘中,读取时只需反序列化该文件即可,实现了封装性。

使用场景

1、数据持久化

将内存中的对象保存到磁盘或数据库,以便程序重启后恢复状态。
示例

  • 游戏存档:保存玩家等级、装备等复杂数据。

  • 应用配置:存储用户设置的偏好(如主题、语言)。

  • 缓存数据:临时保存计算结果,避免重复计算。

2、网络通信(进程线程间)

在不同服务、设备或语言之间传输结构化数据。
示例

  • API接口:客户端与服务端通过JSON/XML交换数据。

  • 微服务调用:gRPC使用Protobuf序列化数据。

  • 消息队列:Kafka、RabbitMQ传输序列化的消息。

具体实例

使用C#保存对象,将对象序列化为二进制进行存储。

复制代码
// 1、首先引入二进制序列化库
using System.Runtime.Serialization.Formatters.Binary;

// 2、在类上面加可序列化标志,即[Serializable]
[Serializable]
class Student
{
    public string Name;
    public int Age;
    public char Sex;
    public String Birthday;
}

// 3、序列化
        //[1]创建文件流
        FileStream fs = new FileStream("obj.stu", FileMode.Create);
        //[2]创建二进制序列化器
        BinaryFormatter bf = new BinaryFormatter();
        //[3]调用序列化方法
        bf.Serialize(fs, stu);
        //[4]关闭文件流
        fs.Close();

        //[1]创建文件流
        FileStream fs2 = new FileStream("obj.stu", FileMode.Open);
        //[2]创建二进制序列化器
        BinaryFormatter bf2 = new BinaryFormatter();
        //[3]调用反序列化方法
        Student[] stu3 = (Student[])bf2.Deserialize(fs2);
        //[4]关闭文件流
        fs.Close();
相关推荐
bugcome_com3 小时前
C# 程序结构详解:从 Hello World 开始
c#
唐梓航-求职中3 小时前
编程-技术-算法-leetcode-288. 单词的唯一缩写
算法·leetcode·c#
bugcome_com6 小时前
阿里云 OSS C# SDK 使用实践与参数详解
阿里云·c#
懒人咖16 小时前
缺料分析时携带用料清单的二开字段
c#·金蝶云星空
bugcome_com16 小时前
深入了解 C# 编程环境及其开发工具
c#
wfserial18 小时前
c#使用微软自带speech选择男声仍然是女声的一种原因
microsoft·c#·speech
阔皮大师20 小时前
INote轻量文本编辑器
java·javascript·python·c#
kylezhao201921 小时前
C# 中的 SOLID 五大设计原则
开发语言·c#
啦啦啦_999921 小时前
Redis-5-doFormatAsync()方法
数据库·redis·c#
Porco.w1 天前
C#与三菱PLC FX5U通信
网络·c#