.NET 6新特性 | System.Text.Json功能改进

news/2024/10/16 17:09:37 标签: .netcore

在.NET 6.0中,JSON处理库得到了显著的改进,主要体现在System.Text.Json上。以下是对.NET 6.0中改进的JSON处理库的详细分析:

一、System.Text.Json的引入与优势

在.NET 6中,Microsoft引入了新的JSON库System.Text.Json作为官方推荐的序列化框架,取代了以前常用的Newtonsoft.Json(Json.NET)。System.Text.Json提供了以下优势:

  1. 性能提升:System.Text.Json使用了更少的内存开销,并且在处理大量数据时有显著的速度优势。这得益于其高效的序列化和反序列化机制,以及针对JSON处理进行的深度优化。
  2. API更简洁:System.Text.Json的API设计更为直观和简单,许多操作可以直接通过LINQ表达式完成。这使得开发者在处理JSON数据时更加便捷和高效。
  3. 兼容性强:虽然Json.NET支持的功能丰富,但大部分情况下System.Text.Json足够满足需求。同时,它能更好地与.NET的其他部分集成,提供了一致的编程体验。

二、System.Text.Json的新特性

在.NET 6中,System.Text.Json引入了多项新特性,以增强其功能和灵活性:

2.1 忽略循环引用

在.NET 6中,System.Text.Json允许在序列化时忽略循环引用,避免了因循环依赖而导致的异常。这通过JsonSerializerOptions中的ReferenceHandler.IgnoreCycles选项来实现。

using System;  
using System.Text.Json;  
using System.Text.Json.Serialization;  
  
public class Person  
{  
    public string Name { get; set; }  
    public Person BestFriend { get; set; }  
}  
  
public class Program  
{  
    public static void Main()  
    {  
        var person = new Person  
        {  
            Name = "Alice",  
            BestFriend = new Person  
            {  
                Name = "Bob",  
                BestFriend = new Person { Name = "Alice" } // 循环引用  
            }  
        };  
  
        var options = new JsonSerializerOptions  
        {  
            ReferenceHandler = ReferenceHandler.IgnoreCycles  
        };  
  
        string json = JsonSerializer.Serialize(person, options);  
        Console.WriteLine(json);  
    }  
}

在这个例子中,Person类有一个BestFriend属性,它指向另一个Person对象。如果BestFriend的BestFriend又指向原始对象,就会形成循环引用。通过设置JsonSerializerOptions的ReferenceHandler为IgnoreCycles,System.Text.Json会忽略这种循环引用,避免序列化时出现异常。 

2.2 序列化和反序列化的通知

System.Text.Json公开了序列化和反序列化的通知接口,如IJsonOnDeserialized、IJsonOnDeserializing、IJsonOnSerialized和IJsonOnSerializing。这使得开发者可以在序列化和反序列化过程中执行自定义逻辑。

using System;  
using System.Text.Json;  
using System.Text.Json.Serialization;  
  
public class Person  
{  
    [JsonPropertyName("name")]  
    public string Name { get; set; }  
  
    [OnDeserialized]  
    public void OnDeserialized()  
    {  
        Console.WriteLine("Deserialized!");  
    }  
  
    [OnDeserializing]  
    public void OnDeserializing()  
    {  
        Console.WriteLine("Deserializing!");  
    }  
  
    [OnSerialized]  
    public void OnSerialized()  
    {  
        Console.WriteLine("Serialized!");  
    }  
  
    [OnSerializing]  
    public void OnSerializing()  
    {  
        Console.WriteLine("Serializing!");  
    }  
}  
  
public class Program  
{  
    public static void Main()  
    {  
        var person = new Person { Name = "Alice" };  
  
        string json = JsonSerializer.Serialize(person);  
        Console.WriteLine(json);  
  
        Person deserializedPerson = JsonSerializer.Deserialize<Person>(json);  
    }  
}

在这个例子中,Person类实现了IJsonOnDeserialized、IJsonOnDeserializing、IJsonOnSerialized和IJsonOnSerializing接口中的方法。这些方法在序列化和反序列化过程中会被自动调用,允许开发者在这些过程中执行自定义逻辑。

2.3 属 性排序支持

通过JsonPropertyOrderAttribute特性,System.Text.Json允许控制属性的序列化顺序。这解决了之前序列化顺序由反射顺序决定的问题,提供了更灵活的属性排序方式。

using System;  
using System.Text.Json;  
using System.Text.Json.Serialization;  
  
[JsonPropertyOrder(nameof(LastName), nameof(FirstName))]  
public class Person  
{  
    public string FirstName { get; set; }  
    public string LastName { get; set; }  
}  
  
public class Program  
{  
    public static void Main()  
    {  
        var person = new Person { FirstName = "John", LastName = "Doe" };  
  
        string json = JsonSerializer.Serialize(person);  
        Console.WriteLine(json); // 输出: {"LastName":"Doe","FirstName":"John"}  
    }  
}

在这个例子中,Person类使用了JsonPropertyOrderAttribute来指定属性的序列化顺序。在这个例子中,LastName会在FirstName之前被序列化。 

2.4 Utf8JsonWriter的使用

System.Text.Json提供了Utf8JsonWriter类,用于高效地编写原始JSON。这使得开发者可以直接操作JSON的字节流,提高了JSON生成的效率和灵活性。

using System;  
using System.Buffers.Text;  
using System.Text.Json;  
  
public class Program  
{  
    public static void Main()  
    {  
        using (var doc = new Utf8JsonWriter(new ArrayBufferWriter<byte>()))  
        {  
            doc.WriteStartObject();  
            doc.WriteString("name", "Alice");  
            doc.WriteNumber("age", 30);  
            doc.WriteEndObject();  
  
            string json = Encoding.UTF8.GetString(doc.Flush());  
            Console.WriteLine(json);  
        }  
    }  
}
2.5 对IAsyncEnumerable的支持

System.Text.Json现在支持(反)序列化JSON数组为IAsyncEnumerable<T>类型,这使得在处理大量数据时可以更加高效地利用异步编程模式。

using System;  
using System.Collections.Generic;  
using System.IO;  
using System.Linq;  
using System.Text.Json;  
using System.Threading.Tasks;  
  
public class Program  
{  
    public static async Task Main()  
    {  
        async IAsyncEnumerable<int> GetNumbersAsync()  
        {  
            for (int i = 0; i < 10; i++)  
            {  
                await Task.Delay(100); // 模拟异步操作  
                yield return i;  
            }  
        }  
  
        using (var stream = new MemoryStream())  
        using (var writer = new Utf8JsonWriter(stream))  
        {  
            writer.WriteStartArray();  
            await foreach (var number in GetNumbersAsync())  
            {  
                writer.WriteNumberValue(number);  
            }  
            writer.WriteEndArray();  
  
            string json = Encoding.UTF8.GetString(stream.ToArray());  
            Console.WriteLine(json);  
        }  
    }  
}

在这个例子中,GetNumbersAsync是一个返回IAsyncEnumerable<int>的异步方法。Utf8JsonWriter被用来将异步生成的数字序列化为JSON数组。这种方式对于处理大量数据或需要异步操作的场景特别有用。

三、与Newtonsoft.Json的比较

尽管Newtonsoft.Json在过去一直是.NET生态中处理JSON的流行选择,但System.Text.Json在.NET 6中的引入提供了以下优势:

  1. 性能优势:System.Text.Json在性能和内存使用方面通常优于Newtonsoft.Json,特别是在处理大量数据时。
  2. 内置支持:System.Text.Json内置于.NET 6核心库中,不需要额外安装,降低了项目的依赖性和复杂性。
  3. 一致性:System.Text.Json与.NET的其他部分更好地集成,提供了一致的编程体验。

然而,Newtonsoft.Json仍然是一个功能丰富的JSON库,提供了许多高级特性和自定义选项。如果项目需要这些高级特性或已经在使用Newtonsoft.Json,并且没有性能或内存使用方面的问题,那么继续使用Newtonsoft.Json也是一个可行的选择。

综上所述,.NET 6.0中的System.Text.Json库在性能、API简洁性、兼容性以及新特性方面都有显著的改进。这些改进使得System.Text.Json成为处理JSON数据的强大工具,为.NET开发者提供了更高效、更便捷的JSON处理能力。


http://www.niftyadmin.cn/n/5708257.html

相关文章

学会组装、调试、维修无人机后从事飞手工作技术优势分析

学会组装、调试、维修无人机后从事飞手工作&#xff0c;将带来显著的技术优势&#xff0c;这些优势不仅提升了飞手的综合能力&#xff0c;也增强了其在行业中的竞争力。以下是对这些技术优势的详细分析&#xff1a; 一、深入理解无人机结构与功能 1. 结构认知&#xff1a;通过…

STM32G474硬件I2C之配置方法

STM32G474硬件I2C接口&#xff1a;英文Inter-integrated circuit简写为I2C。STM32G474是M4核&#xff0c;在使用硬件I2C时&#xff0c;配置方法和M3核相差较大。通过阅读参考手册和HAL&#xff0c;总算了解了其配置原理。 1、I2C工作模式 I2C标准模式&#xff1a;最高时钟频率…

Windows 添加右键以管理员身份运行 PowerShell

在 Windows 系统中添加一个右键菜单选项&#xff0c;以便可以使用管理员权限打开 PowerShell&#xff0c;可以通过编辑注册表来实现。 打开注册表编辑器&#xff1a; 按 Win R 打开运行对话框。输入 regedit 并按回车&#xff0c;这将打开注册表编辑器。 导航到文件夹背景键&…

2024-10-15 学习人工智能的Day7

在简单的了解完学习人工智能所需的高数、线代、概率论后&#xff0c;我们又重新开始了国庆的学习&#xff0c;因为已经有十余天没有接触python&#xff0c;所以今天的内容主要是对之前学习的python的回顾与总结&#xff0c;然后对各个部分进行了简单的实践&#xff0c;在最后学…

Linux的zookeeper安装部署

1.zookeeper是一个分布式的,开放源码的分布式应用程序协调服务,是hadoop和HBASE的重要组件 2.下载zookeeper安装包zookeeper安装包https://archive.apache.org/dist/zookeeper/zookeeper-3.5.9/ 移动到Linux解压 解压到/export/server文件夹 命令: tar -xvf apache-zooke…

Java实现八种排序

目录 分类 直接插入排序 希尔排序 选择排序 堆排序 冒泡排序 快速排序 挖坑法 hoare法 双指针法 优化 非递归实现 归并排序 非递归实现 计数排序 分类 这里的排序可以分为两大类&#xff0c; 基于比较的排序非基于比较的排序 其中有七种基于比较的排序&…

Reality Capture 软件安装 附下载链接

Reality Capture 软件安装 文章目录 Reality Capture 软件安装一、Reality Capture v1.4汉化版安装包下载并解压二、Epic Games Launcher安装三、设置路径并安装![在这里插入图片描述](https://i-blog.csdnimg.cn/direct/f077210990674d9fa9c10b52338b52fe.png)四、启动Epic Ga…

Jmeter脚本录制、Badboy脚本录制

目录 Jmeter脚本录制 Badboy脚本录制 Jmeter脚本录制 1、首先添加一个http测试脚本记录器 2、选择目标控制器&#xff0c;把录制的内容放到的地方 3、分组&#xff0c;就是在录制的时候&#xff0c;每一步操作之间间隔方式&#xff0c;根据自己需要进行选择 4、开启浏览…