0

0

c# 高并发下使用 System.Text.Json 的 JsonSerializerContext 提升性能

月夜之吻

月夜之吻

发布时间:2026-01-15 10:26:02

|

634人浏览过

|

来源于php中文网

原创

JsonSerializerContext通过预编译序列化逻辑、避免反射与锁竞争、实现线程安全零分配来提升高并发性能;需继承基类、用[JsonSerializable]标记类型、启用源生成,并复用静态实例配合泛型API调用。

c# 高并发下使用 system.text.json 的 jsonserializercontext 提升性能

为什么 JsonSerializerContext 能在高并发下提升性能

因为 JsonSerializerContext 预编译了类型序列化逻辑,避免每次调用 JsonSerializer.Serialize 时重复反射、生成委托、构建缓存键。在高并发场景下,反复创建 JsonSerializerOptions 或依赖默认上下文会触发锁竞争和 GC 压力,而静态复用的 JsonSerializerContext 子类是线程安全且零分配(对已知类型)。

如何正确定义和使用 JsonSerializerContext 子类

必须继承抽象基类 JsonSerializerContext,用 [JsonSerializable] 标记要支持的类型,并启用源生成(Source Generator)。不能手动 new 它,也不能把它当普通类随意实例化。

  • 项目需启用源生成:在 .csproj 中添加 true(.NET 7+ 推荐),或显式引用 System.Text.Json.SourceGeneration
  • JsonSerializerContext 子类必须是 public sealed,且构造函数为 internalprotected
  • 每个上下文应聚焦一组相关类型,避免把几十个 DTO 全塞进一个上下文——类型过多会导致生成代码膨胀、编译变慢、热重载失败
public static partial class MyJsonContext : JsonSerializerContext
{
    [JsonSerializable(typeof(Order))]
    [JsonSerializable(typeof(List))]
    [JsonSerializable(typeof(Dictionary))]
    public static partial JsonTypeInfo Order { get; }
    public static partial JsonTypeInfo> OrderList { get; }
}

高并发中怎么传参、怎么选 API

核心原则:复用同一个 JsonSerializerContext 实例,且优先使用泛型重载,避免运行时类型擦除带来的装箱或反射回退。

网胜B2B电子商务系统蓝色风格 2008 SP6.2 普及版
网胜B2B电子商务系统蓝色风格 2008 SP6.2 普及版

  websenB2B是一套经过完善设计的B2B行业网站程序,是windows nt系列环境下最佳的B2B行业网产站解决方案。精心设计的架构与功能机制,适合从个人到企业各方面应用的要求,为您提供一个安全、稳定、高效、易用而快捷的行业网站商务系统。分普及版和商业版等不同版本。一、网胜B2B电子商务系统SP6.2蓝色风格普及版本升级功能说明:1、邮件群发功能:可以选择某一级别的会员,并放入支持html

下载
  • 序列化时用 JsonSerializer.Serialize(output, value, context.Order),而不是 JsonSerializer.Serialize(output, value, options) —— 后者绕过源生成,退化为传统路径
  • 反序列化必须指定具体 JsonTypeInfo,例如 JsonSerializer.Deserialize(input, MyJsonContext.Order);若只传 context 不传 JsonTypeInfo,会触发内部查找逻辑,失去性能优势
  • 不要在请求处理中 new 上下文实例:所有 JsonSerializerContext 子类都应通过静态属性暴露,如 MyJsonContext.Default 或直接用生成的 static partial 属性

容易被忽略的坑和兼容性限制

源生成不是万能的,很多动态场景它不支持,强行用反而引发运行时异常或静默退化。

  • 不支持运行时才确定的泛型参数(如 T 来自方法参数且未在 [JsonSerializable] 中声明)
  • 不支持 objectdynamicExpandoObject 等无固定结构类型——它们仍走反射路径,且无法被 JsonSerializerContext 捕获
  • .NET 6 的源生成是实验性功能,.NET 7+ 才稳定;若项目混用旧版 SDK 或 CI 环境未升级,可能生成失败但不报错,导致上线后性能骤降
  • 调试时注意:生成的代码在 obj/Debug/... 下,若清理不彻底,可能引用旧版 JsonTypeInfo 导致序列化结果不一致

最常出问题的是「以为加了 [JsonSerializable] 就万事大吉」,实际没检查生成是否成功、没验证泛型绑定是否精确、也没压测对比分配率——这些地方一漏,高并发下的性能收益就归零。

相关文章

数码产品性能查询
数码产品性能查询

该软件包括了市面上所有手机CPU,手机跑分情况,电脑CPU,电脑产品信息等等,方便需要大家查阅数码产品最新情况,了解产品特性,能够进行对比选择最具性价比的商品。

下载

本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

相关专题

更多
json数据格式
json数据格式

JSON是一种轻量级的数据交换格式。本专题为大家带来json数据格式相关文章,帮助大家解决问题。

411

2023.08.07

json是什么
json是什么

JSON是一种轻量级的数据交换格式,具有简洁、易读、跨平台和语言的特点,JSON数据是通过键值对的方式进行组织,其中键是字符串,值可以是字符串、数值、布尔值、数组、对象或者null,在Web开发、数据交换和配置文件等方面得到广泛应用。本专题为大家提供json相关的文章、下载、课程内容,供大家免费下载体验。

532

2023.08.23

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

309

2023.10.13

go语言处理json数据方法
go语言处理json数据方法

本专题整合了go语言中处理json数据方法,阅读专题下面的文章了解更多详细内容。

74

2025.09.10

线程和进程的区别
线程和进程的区别

线程和进程的区别:线程是进程的一部分,用于实现并发和并行操作,而线程共享进程的资源,通信更方便快捷,切换开销较小。本专题为大家提供线程和进程区别相关的各种文章、以及下载和课程。

480

2023.08.10

default gateway怎么配置
default gateway怎么配置

配置default gateway的步骤:1、了解网络环境;2、获取路由器IP地址;3、登录路由器管理界面;4、找到并配置WAN口设置;5、配置默认网关;6、保存设置并退出;7、检查网络连接是否正常。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

219

2023.12.07

点击input框没有光标怎么办
点击input框没有光标怎么办

点击input框没有光标的解决办法:1、确认输入框焦点;2、清除浏览器缓存;3、更新浏览器;4、使用JavaScript;5、检查硬件设备;6、检查输入框属性;7、调试JavaScript代码;8、检查页面其他元素;9、考虑浏览器兼容性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

180

2023.11.24

Java 桌面应用开发(JavaFX 实战)
Java 桌面应用开发(JavaFX 实战)

本专题系统讲解 Java 在桌面应用开发领域的实战应用,重点围绕 JavaFX 框架,涵盖界面布局、控件使用、事件处理、FXML、样式美化(CSS)、多线程与UI响应优化,以及桌面应用的打包与发布。通过完整示例项目,帮助学习者掌握 使用 Java 构建现代化、跨平台桌面应用程序的核心能力。

61

2026.01.14

php与html混编教程大全
php与html混编教程大全

本专题整合了php和html混编相关教程,阅读专题下面的文章了解更多详细内容。

31

2026.01.13

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
WEB前端教程【HTML5+CSS3+JS】
WEB前端教程【HTML5+CSS3+JS】

共101课时 | 8.3万人学习

JS进阶与BootStrap学习
JS进阶与BootStrap学习

共39课时 | 3.2万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号