当前位置: 首页 > news >正文

C# 使用 Source Generation 提升 System.Text.Json 性能

使用 Source Generation 提升 System.Text.Json 性能

  • 使用 Source Generation 提升 System.Text.Json 性能
    • 前言
    • 一、源生成的核心优势
    • 二、实现步骤
      • 1. 定义序列化上下文
      • 2. 序列化/反序列化
    • 三、高级配置
    • 四、项目集成
    • 五、关键注意事项
    • 六、完整案例
      • 数据模型
      • 上下文定义
      • 使用示例
    • 结语

使用 Source Generation 提升 System.Text.Json 性能

前言

在 C# 开发中,System.Text.Json 是处理 JSON 数据的主流方案。传统的反射式序列化虽然方便,但在高频调用AOT场景(如 iOS/Blazor WASM)中会遇到性能瓶颈。.NET 6+ 引入的 Source Generation(源生成) 技术,通过在编译时生成序列化代码,可显著提升性能。本文将详解其实现方式。


一、源生成的核心优势

特性反射方案源生成方案
启动速度首次调用需初始化反射元数据无运行时开销
AOT 支持不可用完全支持
序列化吞吐量约 1x约 1.5-2x
内存占用较高(反射缓存)低(编译时生成代码)

适用场景

  • 需要减少应用启动时间的服务
  • 移动端/WebAssembly 等 AOT 环境
  • 高频调用的 JSON API 接口

二、实现步骤

1. 定义序列化上下文

创建继承自 JsonSerializerContext 的分部类,并通过 [JsonSerializable] 注册类型:

[JsonSerializable(typeof(Product))]
[JsonSerializable(typeof(List<Product>))]
public partial class AppJsonContext : JsonSerializerContext
{// 源生成器自动填充实现
}

2. 序列化/反序列化

使用生成的 Default 实例进行高效操作:

// 序列化
var product = new Product { Id = 100, Name = "Keyboard" };
string json = JsonSerializer.Serialize(product, AppJsonContext.Default.Product);// 反序列化
Product? result = JsonSerializer.Deserialize(json, AppJsonContext.Default.Product);

三、高级配置

通过 [JsonSourceGenerationOptions] 定制行为:

[JsonSourceGenerationOptions(PropertyNamingPolicy = JsonKnownNamingPolicy.CamelCase,WriteIndented = true,DefaultIgnoreCondition = JsonIgnoreCondition.WhenWritingNull,NumberHandling = JsonNumberHandling.AllowReadingFromString)]
[JsonSerializable(typeof(Product))]
public partial class AppJsonContext : JsonSerializerContext
{
}

常用配置项

  • PropertyNamingPolicy: 命名策略(如 CamelCase)
  • WriteIndented: 是否美化输出
  • IgnoreNullValues: 空值忽略规则
  • Converters: 自定义类型转换器

四、项目集成

.csproj 中启用源生成:

<PropertyGroup><EnableSourceGenerator>true</EnableSourceGenerator>
</PropertyGroup>

注意:需安装 System.Text.Json 7.0+ 包


五、关键注意事项

  1. 类型可见性
    如果目标类型为 internal,需在 AssemblyInfo.cs 添加:

    [assembly: InternalsVisibleTo("YourAssemblyName")]
    
  2. 编译时验证
    所有被序列化的属性必须具有可访问的 getter/setter

  3. 集合类型
    建议直接注册 List<T> 而非 IEnumerable<T> 以提高性能


六、完整案例

数据模型

public class Product
{public int Id { get; set; }public string? Name { get; set; }public DateTimeOffset CreatedAt { get; set; }
}

上下文定义

[JsonSourceGenerationOptions(WriteIndented = true)]
[JsonSerializable(typeof(Product))]
public partial class ProductContext : JsonSerializerContext
{
}

使用示例

var products = new List<Product>
{new Product { Id = 1, Name = "Mouse", CreatedAt = DateTimeOffset.UtcNow },new Product { Id = 2, Name = "Monitor", CreatedAt = DateTimeOffset.UtcNow }
};// 序列化集合
string json = JsonSerializer.Serialize(products, ProductContext.Default.ListProduct
);// 输出结果
// [
//   {
//     "Id": 1,
//     "Name": "Mouse",
//     "CreatedAt": "2023-09-20T08:30:00+00:00"
//   },
//   ...
// ]

结语

源生成技术通过编译时生成优化代码,不仅提升了性能,还增强了 AOT 兼容性。对于追求极致性能的 .NET 应用,这是 JSON 处理的首选方案。建议在复杂DTO场景中优先采用此方案。

http://www.xdnf.cn/news/581131.html

相关文章:

  • 职坐标嵌入式MCU/DSP与RTOS开发精讲
  • Android logcat命令汇总
  • Elasticsearch 写入性能优化有哪些常见手段?
  • c++11特性——lambda对象、包装器
  • Strands Agents:AWS开源Agent框架的技术与应用全景
  • MySQL 索引失效及其解决办法
  • 全面学习c++类与对象(中)(非常重要)(析构构造拷贝函数赋值运算符重载等等)
  • 养生攻略:五步打造健康生活
  • Three.js搭建小米SU7三维汽车实战(1)搭建开发环境
  • 腾讯云媒体AI解码全球视频出海智能密码
  • 替代云数据库的本地方案:MySQL+phpMyAdmin的远程管理与跨网络访问技术
  • Windows下PyCharm2025的运行卡顿的问题
  • 介绍一下 MVCC
  • 2025最新版Visual Studio Code for Mac安装使用指南
  • Spark入门秘籍
  • Docker 疑难杂症解决指南大纲
  • 人民日报社主管媒体深度聚焦珈和科技“遥感+AI”农险精准化突破:首创“四维数据贯通”模式 树行业转型新标杆
  • RNN神经网络
  • tmagic-editor本地实践(2)
  • 当物联网“芯”闯入纳米世界:ESP32-S3驱动的原子力显微镜能走多远?
  • centos8 配置网桥,并禁止kvm默认网桥
  • WPF 常见坑:ContentControl 不绑定 Content 时,命令为何失效?
  • 使用 Selenium 自动化测试:保存网站登录数据的详细指南
  • Labview实现计算CPK参数
  • Appium 的 enableMultiWindows 参数
  • React+Taro 微信小程序做一个页面,背景图需贴手机屏幕最上边覆盖展示
  • 基于 WebRTC 的一对一屏幕共享项目(一)——项目简介
  • 深入解析Spring Boot与Redis集成:高效缓存与性能优化
  • ETL 代表什么?ETL 开发主要做什么?
  • web第六次课后作业--使用ApiFox实现请求响应操作