.net core 为什么使用 null!

为什么使用 null!

通常在以下几种情况中,你可能会使用 null!

  • 属性值可能会在对象构造或某个方法中被初始化,但在构造函数或者对象完全初始化之前,属性的值可能会是 null
  • 你知道这个属性最终会被赋一个非 null 的值,但编译器在静态分析时可能不能完全理解这种情况,使用 null! 可以让编译器跳过相关的警告。

示例:

cs 复制代码
public class Person
{
    public string Name { get; set; } = null!;

    public Person(string name)
    {
        Name = name;  // 通过构造函数赋值,确保 Name 不会是 null
    }
}

在这个例子中,Name 属性初始时赋值为 null!,然后在构造函数中通过 name 参数将其赋值为一个实际的非 null 值。这样可以避免编译器的警告。

重点总结:

  • null! 是用于在你确信后续代码中不会出现 null 引用时抑制编译器的警告。
  • 可空引用类型空值抑制操作符(! 是 C# 8.0 引入的特性,目的是提高代码的健壮性,避免 null 引用异常(NullReferenceException)。

通过这种方式,开发者可以更灵活地处理属性的初始化和赋值,同时避免不必要的编译器警告。

相关推荐
火星papa37 分钟前
C# 阻塞队列(BlockingCollection)
c#·queue·阻塞队列
xuankuxiaoyao2 小时前
Vue.js实践-组件基础下
前端·javascript·vue.js
小白学大数据2 小时前
JS 混淆加密下的 Python 爬虫解决方案
javascript·爬虫·python
大家的林语冰3 小时前
前端周刊:axios 疑遭朝鲜黑客“钓鱼“;CSS 新函数上线;npm 上线深色主题;Oxlint 兼容表;ESLint 支持 Temporal......
前端·javascript·css
竹林8185 小时前
用ethers.js连接MetaMask实现Web3钱包登录:从踩坑到稳定运行的完整记录
前端·javascript
心连欣5 小时前
从零开始,学习所有指令!
前端·javascript·vue.js
OctShop大型商城源码6 小时前
.NET线上商城源码_C#商城源码_技术赋能下的电商新生态
开发语言·c#·.net·商城系统源码
openKaka_7 小时前
从 scheduleUpdateOnFiber 到 Root 微任务调度:React 如何把更新交给调度系统
开发语言·前端·javascript
前进的李工7 小时前
智能Agent实战指南:记忆组件嵌入技巧(记忆)
开发语言·前端·javascript·python·langchain·agent