c#XML、JSON的序列化和反序列化,看完你就懂了

简介: c#XML、JSON的序列化和反序列化,看完你就懂了

序列化和反序列化是C#编程中非常常见的概念,这两个概念在面向对象编程中起着至关重要的作用,可以实现对象的持久化存储和传输。本篇文章将为大家详细介绍C#中的序列化和反序列化,并分别阐述XML和Json两种格式的序列化和反序列化的实现方式。


一、序列化的概念


序列化是指将数据结构或对象转换为一组字节,以便可以将其存储在磁盘或在网络上传输,然后在需要的时候重新创建相同的数据结构或对象。简单来说,序列化就是将一个对象转换成字节流或者XML文本格式。


二、序列化的实现


C#中所使用的序列化和反序列化的方法,包含两种格式:XML和Json。


  1. XML序列化和反序列化

在 C# 中,可以使用 System.Xml.Serialization 命名空间中的 XmlSerializer 类来进行 XML 格式的序列化和反序列化。


1.1 XML序列化

使用 XML 序列化器将对象序列化为 XML 文档,首先需要定义要序列化的类或结构体,然后使用 XmlSerializer 类的 Serialize() 方法将其序列化为 XML 文档。示例代码如下:


using System;
using System.Xml.Serialization;
using System.IO;
 
[Serializable]
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}
 
class Program
{
    static void Main(string[] args)
    {
        Person person = new Person() { Name = "Tom", Age = 20 };
 
        XmlSerializer serializer = new XmlSerializer(typeof(Person));
 
        using (TextWriter writer = new StreamWriter(@"D:\person.xml"))
        {
            serializer.Serialize(writer, person);
        }
    }
}


1.2 XML反序列化

使用 XML 序列化器将 XML 文档反序列化为对象,首先需要使用 XmlSerializer 类的 Deserialize() 方法将 XML 文档反序列化为对象。示例代码如下:

using System;
using System.Xml.Serialization;
using System.IO;
 
[Serializable]
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}
 
class Program
{
    static void Main(string[] args)
    {
        XmlSerializer serializer = new XmlSerializer(typeof(Person));
 
        using (FileStream fileStream = new FileStream(@"D:\person.xml", FileMode.Open))
        {
            Person person = serializer.Deserialize(fileStream) as Person;
            Console.WriteLine("Name: " + person.Name);
            Console.WriteLine("Age: " + person.Age);
        }
    }
}


在上述代码段中,使用文件流读取 XML 文档,然后反序列化为 Person 类型的对象,最后输出 Name 和 Age 属性的值。


  1. Json序列化和反序列化

在C#中,可以使用 Newtonsoft.Json 库提供的 JsonConvert 类来进行Json格式的序列化和反序列化。


2.1 Json序列化

使用Json序列化器将对象序列化为Json文档,首先需要定义要序列化的类或结构体,然后使用 JsonConvert 类的 SerializeObject() 方法将其序列化为 Json 文档。示例代码如下:

using Newtonsoft.Json;
using System;
 
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}
 
class Program
{
    static void Main(string[] args)
    {
        Person person = new Person() { Name = "Tom", Age = 20 };
 
        string json = JsonConvert.SerializeObject(person);
 
        Console.WriteLine("Json: " + json);
    }
}


在上述代码段中,使用 JsonConvert.SerializeObject()方法将Person 类对象序列化为Json格式,最后输出Json字符串到控制台。


2.2 Json反序列化


使用Json序列化器将Json文档反序列化为对象,首先需要使用 JsonConvert 类的 DeserializeObject() 方法将 Json 文档反序列化为对象,然后将反序列化后的对象转换为指定的类型。示例代码如下:

using Newtonsoft.Json;
using System;
 
public class Person
{
    public string Name { get; set; }
    public int Age { get; set; }
}
 
class Program
{
    static void Main(string[] args)
    {
        string json = "{ Name:'Tom', Age:20 }";
 
        Person person = JsonConvert.DeserializeObject<Person>(json);
 
        Console.WriteLine("Name: " + person.Name);
        Console.WriteLine("Age: " + person.Age);
    }
}


在上述代码段中,JsonConvert.DeserializeObject()方法实现反序列化,将Json字符串转换为Person类型对象,最后输出Name和Age属性的值。


三、总结


C#中的序列化和反序列化是实现持久化存储和网络传输的关键手段。XML序列化和反序列化采用XmlSerializer类的方法实现,Json序列化和反序列化采用Newtonsoft.Json库的方法来实现。这两种方法都可以实现对象的序列化和反序列化,但在具体的场景中,选择哪种序列化方式取决于具体的需求,从而实现更好的效果。


相关文章
|
4天前
|
存储 C#
C#中的序列化和反序列化
C#中的序列化和反序列化
23 0
|
4天前
|
XML C# 数据格式
使用C#操作XML文件
使用C#操作XML文件
14 0
|
4天前
|
XML C# 数据格式
C# 解析XML文件
C# 解析XML文件
59 1
|
4天前
|
存储 JSON JavaScript
Python中的JSON与Pickle模块:数据序列化和反序列化的利器
在Python编程中,数据的序列化和反序列化是经常遇到的操作。序列化是将数据结构或对象状态转换为可以存储或传输的格式的过程,而反序列化则是这个过程的逆操作,即将序列化的数据重新转换回原来的数据结构或对象状态。Python中的JSON和Pickle模块就是实现数据序列化和反序列化的强大工具。
|
4天前
|
存储 C#
C#中的序列化和反序列化案例
C#中的序列化和反序列化案例
16 0
|
4天前
|
JSON 前端开发 Java
Json格式数据解析
Json格式数据解析
|
4天前
|
存储 JSON 数据处理
从JSON数据到Pandas DataFrame:如何解析出所需字段
从JSON数据到Pandas DataFrame:如何解析出所需字段
16 1
|
2天前
|
JSON NoSQL MongoDB
实时计算 Flink版产品使用合集之要将收集到的 MongoDB 数据映射成 JSON 对象而非按字段分割,该怎么操作
实时计算Flink版作为一种强大的流处理和批处理统一的计算框架,广泛应用于各种需要实时数据处理和分析的场景。实时计算Flink版通常结合SQL接口、DataStream API、以及与上下游数据源和存储系统的丰富连接器,提供了一套全面的解决方案,以应对各种实时计算需求。其低延迟、高吞吐、容错性强的特点,使其成为众多企业和组织实时数据处理首选的技术平台。以下是实时计算Flink版的一些典型使用合集。
28 1
|
4天前
|
XML JSON API
转Android上基于JSON的数据交互应用
转Android上基于JSON的数据交互应用
11 1
|
4天前
|
JSON JavaScript Java
从前端Vue到后端Spring Boot:接收JSON数据的正确姿势
从前端Vue到后端Spring Boot:接收JSON数据的正确姿势
26 0