.NET中的null可引用类型是什么?如何从项目中根除NullReferenceException?

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

在 .NET 中,null 可引用类型是 C# 8.0 引入的一项重要功能,旨在帮助开发者更早发现潜在的空引用问题。默认情况下,C# 将引用类型(如 string、class 等)视为“可空”,这使得我们很容易在运行时遇到 NullReferenceException。通过启用可空引用类型(nullable reference types),编译器可以在编译期间提示你哪些变量可能为 null,从而减少运行时异常。

可空引用类型是什么?

启用后,引用类型的默认行为变为“不可为空”。如果你希望某个引用类型可以为 null,必须显式添加 ? 标记:

string name;
—— 不可为 null
string? optionalName;
—— 可以为 null

当你尝试解引用一个可能为 null 的变量时,编译器会发出警告。例如:

string? input = GetName();
Console.WriteLine(input.Length); // 警告:可能造成 NullReferenceException

你需要先做 null 检查:

if (input != null)
{
    Console.WriteLine(input.Length);
}

如何启用可空上下文

在项目文件(.csproj)中添加以下配置来启用可空引用类型:

<PropertyGroup>
  <Nullable>enable</Nullable>
</PropertyGroup>

也可以使用 #pragma 在特定文件中控制:

#nullable enable   // 启用
#nullable disable  // 禁用

避免 NullReferenceException 的实用建议

除了启用可空引用类型,还需要结合良好的编程习惯从项目中根除空引用异常:

始终验证外部输入:方法参数来自用户、API 或配置时,应检查是否为 null,并抛出 ArgumentNullException。 使用 null 合并运算符:简化 null 回退逻辑,例如
name ?? "Unknown"
使用 null 条件运算符:避免逐层判空,如
customer?.Order?.Id
,安全访问深层属性。
构造函数中初始化必要字段:确保对象创建后关键成员不为 null。 返回空集合而非 null:对于返回数组或列表的方法,优先返回
new List<t>()</t>
Array.Empty<t>()</t>
使用代码分析工具:配合 ReSharper、Roslyn 分析器等增强静态检查能力。

处理遗留代码中的 null 问题

在老项目中逐步引入可空上下文时,可能会出现大量警告。建议采取渐进方式:

先在项目文件中启用
<nullable>warnings</nullable>
,只提示不强制。
逐个文件修复警告,再切换到
enable
模式。
对暂时无法修改的代码使用
!
操作符(null-forgiving operator)压制警告,但应标注注释后续处理。

基本上就这些。开启可空引用类型不是一劳永逸的解决方案,但它极大提升了代码的健壮性。配合严谨的编码习惯,能显著降低 NullReferenceException 的发生概率。不复杂但容易忽略的是:坚持在团队中统一启用并审查这些警告,才能真正发挥其价值。

相关推荐