在 2025 收官前,看清 Data + AI 的真实走向,点击查看 BUILD 大会精华版 了解详情
写点什么

在 C#6 和 VB 12 中不可变对象 (Immutable Objects ) 更易用

  • 2014-08-18
  • 本文字数:1211 字

    阅读完需:约 4 分钟

.NET 编程中的一个痛点: 为了实现不可变对象 (Immutable Objects ),需要编写大量样板代码。 不可变类 (immutable class) 不同于一个普通的类,它要求每个属性具有一个单独定义的字段,当然,还需要通过一个构造函数来填充每个字段的填。

根据新的规范草案,C#和 VB 将增加一个称为“记录类”(record class)的特性。实质上, 它是仅由在构造函数中定义的不可变类 (immutable class)。

下面是规范的一行代码示例:

public record class Cartesian(double x: X, double y: Y);除了这个构造函数外,编译器会自动创建:

  • 生成每个参数的只读属性(read-only property)
  • 生成 Equals 函数
  • 重写 GetHashCode 函数
  • 重写 ToString 函数
  • 生成一个“is”操作符,在 VB 中称为“Matches”

“is/Matches”操作符被用于模式匹配 (pattern matching),我们会在未来的文章涉及到。除此之外,记录类(record classes)和 C#匿名类型(anonymous types)很相近(和 VB 的匿名类型有所不同,它们默认是可变的)。对这两种概念,微软正研究如何协调,尤其是基于现有的程序集中,还不能对外暴露匿名类型接口。

不可变类型的一个通用特性是在对对象的一个或多个字段进行改变后,会自动产生当前对象的拷贝。虽然在规范中没有提到,但微软正在考虑为 C#提供如下方式作为一种选项:

复制代码
var x1 = new MyRecord(1, 2, 3);
var x2 = x1 with B: 16;
Console.WriteLine(x2) // prints something like "A = 1, B = 16, C = 3"

扩展记录类

你可能已经注意到,在 Cartesian 示例类中,用分号表示结束。表明该类不包含任何类体,只保留由编译器负责自动生成提供的那部分。

除了直接使用分号结束定义,你还可以像一个普通的类一样,通过提供一组大括号,并添加其他属性和方法。编译后,你仍然会得到编译器自动生成的代码。

其他限制

目前还暂时只支持记录类(record classes)。在理论上,也能够使用相同的基本语法和概念进行添加记录结构体(record structs)。

类库支持问题

在.NET 中使用不可变类型(immutable types)有一个严重的限制,即它缺乏广泛的类库支持。想象一下,如果你是一个负责中间层的开发者,那你每日的工作很可能就是通过 ORM 从数据库获取一些对象,然后再序列化到 SOAP-XML 或 JSON,然后以单向或者双向的方式传递给客户端。

但是, 目前的大多数的 ORM 及序列化支持不可变类型(immutable types),它们会假定该类型具有一个无参数的构造函数,并且包含一些可变的属性。如果这个问题没有在这些流行的框架中解决,那么在大多数工程项目中记录类(record classes)将用处不大。

欲了解更多信息,请参见草案规范 Pattern Matching for C#。该原型应该可以在数周内发布。

查看原文链接: Easier Immutable Objects in C# 6 and VB 12


感谢邵思华对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2014-08-18 01:502032
用户头像
王文刚 Instagram 营销专家

发布了 37 篇内容, 共 27.1 次阅读, 收获喜欢 55 次。

关注

评论

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

平凯数据库与鸿翼完成互认证,破解亿级文档管理难题

TiDB 社区干货传送门

金融 智能制造 / 汽车 政府及公共事业

YashanDB数据库基于容器技术的集群部署策略详解

数据库砖家

YashanDB数据库结合机器学习实现智能查询优化探析

数据库砖家

YashanDB 是一种高可扩展性的分布式数据库

数据库砖家

YashanDB数据库跨数据中心同步技术解析

数据库砖家

YashanDB数据库批量数据处理性能优化的核心技巧

数据库砖家

TiDB 企业版敏捷模式试用:政企实战场景体验

TiDB 社区干货传送门

社区活动 TEM 试用 平凯数据库敏捷模式

TiDB v8.5 新特性解读:Region Size 默认提升至 256 MiB

TiDB 社区干货传送门

新版本/特性解读

YashanDB数据库架构演进及性能提升关键技术透析

数据库砖家

YashanDB数据库结合边缘计算实现数据实时处理的实践

数据库砖家

Up!使用 Navicat Premium 连接平凯数据库敏捷模式

TiDB 社区干货传送门

数据库连接 平凯数据库敏捷模式

从“踩坑”到“精通”:TiDB 应用开发实战指南

TiDB 社区干货传送门

性能调优 OLTP HTAP 8.x 实践

YashanDB数据库企业级容灾备份体系建设与实现路径

数据库砖家

YashanDB数据库集群管理的核心技术与实践

数据库砖家

YashanDB数据库可扩展性与未来演进趋势

数据库砖家

YashanDB数据库跨平台数据访问技术及性能优化实践

数据库砖家

唐刘:为什么 TiDB 是 AI as a Service (AIaaS) 的最佳选择

TiDB 社区干货传送门

技术趋势

YashanDB数据库结合云原生架构的最佳实践解析

数据库砖家

YashanDB数据库科技的未来发展:创新与挑战

数据库砖家

YashanDB数据库跨地域数据同步实现方法详解

数据库砖家

YashanDB数据库架构稳定性的五大关键保障措施

数据库砖家

YashanDB数据库结合区块链技术实现数据可信存储探索

数据库砖家

YashanDB数据库迁移最佳实践:从传统系统到现代架构

数据库砖家

使用 Docker Compose 实现 TiDB 平凯数据库敏捷模式的两节点双向复制

TiDB 社区干货传送门

平凯数据库敏捷模式

YashanDB数据库集成的常见挑战与应对策略

数据库砖家

YashanDB数据库跨平台迁移的挑战及应对措施

数据库砖家

大模型训练中的关键技术与挑战:数据采集、微调与资源优化

猫头虎

数据分析 爬虫 数据集 爬虫教程 大模型

YashanDB数据库架构的深入解析与实用建议

数据库砖家

YashanDB数据库架构设计的核心原则及实战经验分享

数据库砖家

YashanDB数据库兼容性测试标准与技术规范全面解析

数据库砖家

YashanDB迁移最佳实践步骤

数据库砖家

在C#6和VB 12中不可变对象(Immutable Objects )更易用_C#_Jonathan Allen_InfoQ精选文章