MemoryPack:极致性能的C二进制序列化器
2026-01-16 10:14:14作者:曹令琨Iris
项目介绍
MemoryPack是一款专为C#和Unity设计的零编码、极致性能的二进制序列化器。它通过零编码设计,直接复制C#内存,实现了比其他序列化器快10倍甚至高达200倍的性能。MemoryPack是作者基于多年序列化器开发经验,利用.NET 7和C# 11的新特性,以及增量源生成器技术,精心打造的一款全新设计的高性能序列化工具。
项目技术分析
MemoryPack的核心优势在于其C#优化的二进制格式和精心调优的实现。它避免了其他序列化器常见的编码操作,如VarInt编码、标签、字符串等,采用了零编码设计,直接复制C#内存,从而实现了极致的性能。此外,MemoryPack支持现代I/O API,如IBufferWriter<byte>、ReadOnlySpan<byte>等,以及原生AOT友好的源生成器代码生成,无动态代码生成(IL.Emit),反射less的非泛型API等。
项目及技术应用场景
MemoryPack适用于需要高性能序列化/反序列化的场景,如游戏开发、高性能服务器、实时数据处理等。特别是在需要处理大量数据或对性能有极高要求的应用中,MemoryPack能够显著提升数据处理的效率和响应速度。
项目特点
- 极致性能:MemoryPack在标准对象上比其他二进制序列化器快10倍,在结构数组上甚至快50到200倍。
- 零编码设计:直接复制C#内存,无需特殊类型,支持POCO(Plain Old CLR Object)。
- 现代I/O API支持:支持
IBufferWriter<byte>、ReadOnlySpan<byte>等现代I/O API。 - 原生AOT友好:基于源生成器的代码生成,无动态代码生成(IL.Emit)。
- 反射less非泛型API:提供反射less的非泛型API,简化使用。
- 多特性支持:支持反序列化到现有实例、多态(Union)序列化、版本容忍、循环引用序列化等。
- 跨平台支持:支持.NET Standard 2.1及Unity(2021.3)IL2CPP。
MemoryPack是一款革命性的序列化工具,它不仅提供了前所未有的性能,还集成了众多现代特性和跨平台支持,是C#和Unity开发者不可或缺的高性能序列化解决方案。
登录后查看全文
项目优选
收起
deepin linux kernel
C
27
11
OpenHarmony documentation | OpenHarmony开发者文档
Dockerfile
509
3.66 K
Ascend Extension for PyTorch
Python
304
348
本项目是CANN提供的数学类基础计算算子库,实现网络在NPU上加速计算。
C++
870
495
openEuler内核是openEuler操作系统的核心,既是系统性能与稳定性的基石,也是连接处理器、设备与服务的桥梁。
C
327
139
暂无简介
Dart
749
180
Nop Platform 2.0是基于可逆计算理论实现的采用面向语言编程范式的新一代低代码开发平台,包含基于全新原理从零开始研发的GraphQL引擎、ORM引擎、工作流引擎、报表引擎、规则引擎、批处理引引擎等完整设计。nop-entropy是它的后端部分,采用java语言实现,可选择集成Spring框架或者Quarkus框架。中小企业可以免费商用
Java
11
1
Dora SSR 是一款跨平台的游戏引擎,提供前沿或是具有探索性的游戏开发功能。它内置了Web IDE,提供了可以轻轻松松通过浏览器访问的快捷游戏开发环境,特别适合于在新兴市场如国产游戏掌机和其它移动电子设备上直接进行游戏开发和编程学习。
C++
52
7
🔥LeetCode solutions in any programming language | 多种编程语言实现 LeetCode、《剑指 Offer(第 2 版)》、《程序员面试金典(第 6 版)》题解
Java
66
20
React Native鸿蒙化仓库
JavaScript
298
347