NVIDIA 初创加速计划,免费加速您的创业启动 了解详情
写点什么

序列化 .NET 中的不可变集合

  • 2013-11-12
  • 本文字数:813 字

    阅读完需:约 3 分钟

.NET 不可变集合的序列化问题现在非常糟糕。如果你使用 DataMember 属性标记一个 ImmutableList类型的属性,那么标准的反序列化器好像会忽略它。没有运行时错误,但是数据就是不存在。

你可以将属性改为 IList 类型从而防止数据丢失,但是这会导致一个语义问题。尽管你可以将一个不可变列表存储到一个 IList 中,但是这种做法令人难以接受,因为大多数人心里面都认为一个给定的 IList 不会是只读的。另外,类型检查器不能在编译时捕获这种错误。

为了解决语义错误,用户认为可以提供一个 IReadOnlyList 类型的属性替代。不幸的是,这样做会在序列化期间抛出一个异常,除非添加了 KnownType 属性。但是一旦添加了该属性在对其序列化时就又会产生无声的错误。

同样地,传统的序列化机制(使用 Serializable 属性)也不支持。Immo Landwerth 写道:

是的。首先,我们使用的可移植子集(portable subset)不支持二进制序列化( visualstudio.uservoice.com/…/3701316-make-the-new-immutable-collection-types-serializab )。其次,我们喜欢一个能够在核心数据结构之外实现序列化的模型,因为这样在客户端 / 服务器场景下使用的时候就可以更加有弹性地实现变化、解决跨版本序列化问题。流行的序列化类库已经计划为不可变集合增加支持,例如 JSON.NET、protobuf-net。

这样我们可以选择第三方类库,例如 JSON.NET。截至版本 5.0r7, JSON.NET 已经支持.NET 官方的不可变集合类库。该版本中的新内容还包括 JsonExtensionData,它会将一个被反序列化类中的所有没有属性表示的附加数据存储起来。

Marc Gravell 还宣称 protobuf-net 将会支持不可变集合

protobuf-net (r666)的主干现在已经支持不可变列表(List)、数组(Array)、字典(Dictionary)、哈希集合(Hash-Set)、排序集合(Sorted-Set)、排序字典(Sorted-Dictionary),同时它们的所有接口都有双份。但是所有内容都在一个单例模式识别块中。

查看英文原文 Serializing Immutable Collections in .NET

2013-11-12 05:121048
用户头像

发布了 321 篇内容, 共 116.0 次阅读, 收获喜欢 18 次。

关注

评论

发布
暂无评论
发现更多内容

架构师训练营--week4

Just顾

系统架构学习总结(训练营第四课)

看山是山

分布式 极客大学架构师训练营

【架构师第四周】总结

浪浪

一个典型的大型互联网应用系统使用了哪些技术

L001

极客大学架构师训练营

第四章作业

小胖子

架构师训练营 - 学习笔记 - 第四周

小遵

一个典型的大型互联网应用系统使用了哪些技术方案和手段,主要解决什么问题?请列举描述。

娄江国

极客大学架构师训练营

学习总结 - 架构师训练营 - 第四周

走过路过飞过

第 04 周作业提交

白杨

架构师训练营第四周作业

fenix

第四周作业

数字

互联网系统架构

陈皮

架构师训练营第四周-总结

王权富贵

极客大学架构师训练营

大型互联网应用系统使用的方案

ashuai1106

架构师 极客大学架构师训练营

架构师第四周-总结

上山砍柴

极客大学架构师训练营

week4.课后作业

个人练习生niki👍

架构师训练营作业 (第四周)

小遵

第四周感想

数字

面向对象学习

一叶知秋

架构师训练营week4学习总结

小高

Week4

架构师训练营 - 第四周 - 作业

Anrika

极客大学架构师训练营

Week 04- 作业一:一个典型的大型互联网应用系统使用了哪些技术方案和手段

dean

极客大学架构师训练营

一个典型的大型互联网应用系统使用了哪些技术方案和手段,主要解决什么问题?请列举描述。

狂奔嘀兔纸

极客大学架构师训练营

架构师训练营 - 作业 - 第四讲

吕浩

架构师训练营 第四周【作业】

小K

第4周总结

娄江国

极客大学架构师训练营

【架构师第四周作业】

浪浪

week4.学习总结

个人练习生niki👍

大型互联网应用系统案例

戴维斯

极客大学架构师训练营

写给大忙人看的进程和线程

cxuan

后端 操作系统

序列化 .NET中的不可变集合_.NET_Jonathan Allen_InfoQ精选文章