Record专为不可变数据设计,强调值语义和简洁语法,适合数据承载;Class支持可变状态与复杂行为,适用于封装逻辑。1. Record默认属性只读,通过with表达式实现非破坏性修改;Class允许直接修改属性。2. Record基于内容进行相等性比较,自动重写Equals/GetHashCode;Class默认按引用比较。3. Record自动生成构造函数、ToString、解构方法;Class需手动实现。4. Record良好支持模式匹配与不可变更新,继承受限;Class支持完整继承体系。根据场景选择可提升代码可维护性。

.NET中的Record和Class都用于定义引用类型,但它们在设计目的、语义和行为上有显著区别。理解这些差异有助于在合适场景选择合适的类型。
1. 设计目的不同:不可变性 vs 可变性
Record 类型专为“数据承载”而设计,强调的是值的表示和不可变性。它默认鼓励使用只读属性,适合表示那些关注“是什么”而不是“做什么”的数据模型。例如用户信息、配置项或DTO(数据传输对象)。
Class 更通用,适用于需要封装状态和行为的对象,支持可变状态,常用于构建业务逻辑、服务类或具有生命周期管理的组件。
Record 通常通过 with 表达式实现非破坏性修改:
- 创建新实例来反映变化,而非修改原对象
- 天然支持函数式编程风格
2. 值语义与引用语义比较
虽然 Record 是引用类型,但它重写了 Equals、GetHashCode 和 ToString 方法,使其表现更像“值相等”。
两个 Record 实例只要所有属性值相同,就被认为是相等的:
- 比较时基于内容,而不是内存地址
- Class 默认按引用比较,除非手动重写 Equals
这意味着你可以直接判断两个 Record 是否“逻辑相等”,而 Class 需要额外代码才能实现相同效果。
3. 简化语法与自动生成成员
Record 支持简写语法,自动合成构造函数、属性访问器和解构方法:
public record Person(string Name, int Age);
上述代码会自动生成:
- 公共只读属性 Name 和 Age
- 一个带有参数的构造函数
- Deconstruct 方法用于解构赋值
- 格式良好的 ToString() 输出(如 Person { Name = "Alice", Age = 30 })
Class 则需要手动编写这些成员,代码更冗长。
4. 继承与模式匹配支持
Record 对模式匹配有良好支持,尤其在 switch 表达式中结合 is 或 switch 使用时更加清晰:
- 可以轻松提取字段进行条件判断
- 配合 with 表达式实现不可变更新
Record 的继承有限制,主要是为了保持值语义一致性。而 Class 支持完整的面向对象继承体系,适合复杂的多态场景。
基本上就这些。Record 更适合表达不可变数据模型,强调简洁和语义清晰;Class 更灵活,适合需要状态管理和复杂行为的场景。根据实际需求选择,能提升代码可读性和维护性。










