C#怎么使用Record类型 C# 9新特性Record使用方法

来源:这里教程网 时间:2026-02-21 17:40:13 作者:

Record类型是C# 9引入的不可变引用类型,专为“数据承载”场景设计,写法简洁、自动具备值语义(如

Equals
GetHashCode
ToString
)、支持非破坏性修改(
with
表达式),非常适合DTO、领域模型、配置项等场景。

基础语法:用record声明不可变数据类型

最简写法类似class,但用

record
关键字:

public record Person(string Name, int Age);

编译器自动生成:

公共只读属性
Name
Age
(对应构造参数)
基于属性值的
Equals
GetHashCode
(值相等判断)
格式化的
ToString()
(如
Person { Name = "张三", Age = 25 }
位置记录(positional record)还自带
Deconstruct
方法,支持解构赋值

自定义属性与构造逻辑

如果需要私有字段、验证逻辑或额外属性,可显式定义:

public record Student(string Name, int Age)
{
    public string Id { get; init; } = Guid.NewGuid().ToString();
    public DateTime CreatedAt { get; init; } = DateTime.Now;
<pre class="brush:php;toolbar:false;">public Student(string name, int age) : this(name, age)
{
    if (string.IsNullOrWhiteSpace(name)) 
        throw new ArgumentException("Name cannot be null or empty");
}

}

注意:

init
访问器允许在对象初始化时(如对象初始化器或
with
中)赋值一次,之后不可变。

用with实现非破坏性修改

record不提供setter,但可用

with
创建副本并修改部分属性:

var p1 = new Person("李四", 30);
var p2 = p1 with { Age = 31 }; // 新实例,Name不变,Age更新
Console.WriteLine(p1 == p2); // false(值不同)
Console.WriteLine(p1.Equals(p2)); // false
Console.WriteLine(p1 with { } == p1); // true(完全相同副本)

with
本质是调用编译器生成的
Clone
逻辑,安全高效,无需手动复制所有字段。

继承与sealed行为

record默认是

sealed
(不可被继承),如需继承,必须显式声明为
record class
并用
virtual
修饰:

public virtual record Animal(string Name);
public record Dog(string Name, string Breed) : Animal(Name);

子record会自动参与值比较(父类+子类所有公开属性参与

Equals
),也支持
with
链式修改。

基本上就这些。Record不是万能替代class的工具,但它让“纯数据对象”的定义变得极其干净——不用手写构造函数、属性、重载方法,也不用依赖第三方库(如AutoMapper或RecordGenerator)。只要你的类型核心诉求是“代表一组不可变的数据”,record就是更自然、更安全的选择。

相关推荐