C#中空值校验应用场景分析

 更新时间:2026年03月09日 10:11:50   作者:元亨利贞448  
文章主要介绍了在C#编程中进行空值校验的重要性,包括校验的必要场景、为什么要做校验以及如何进行校验,校验可以避免空引用异常,保障数据合法性,并提前拦截错误,本文给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧

# 在 C# 编程(尤其是业务开发)中,空值校验是保障程序稳定性、避免空引用异常(`NullReferenceException`)的核心手段。结合你这段物料分类新增的代码,我会从**场景+原因+示例**三个维度,清晰告诉你什么情况必须做空值校验。

 一、必须做空值校验的核心场景

 1. 外部输入/入参校验(最基础也最关键)

**适用场景**:
- 方法/函数的入参(尤其是外部系统、用户输入、第三方接口传递的参数)
- 从配置文件、数据库、消息队列读取的数据
- API 接口接收的请求参数
**为什么要做**:
外部数据不受你的代码控制,可能是 null、空字符串、格式错误等,直接使用会导致程序崩溃。
**对应你代码的示例**:

// 你的代码中对入口参数的校验(必须做)
if (receiveEventInfo == null || string.IsNullOrWhiteSpace(receiveEventInfo.Content))
{
    LogTextHelper.Warn("物料分类新增失败:接收的事件信息为空或内容为空");
    return;
}

如果不校验receiveEventInfo.Content 为 null 时,会直接抛出 NullReferenceException,导致整个方法崩溃,甚至影响调用方。

2. 反序列化/类型转换后的数据校验

适用场景

  • JSON/XML 反序列化后的对象(如你代码中 JsonConvert.DeserializeObject 的结果)
  • 数据库查询结果(如 FindSingle 查不到数据会返回 null)
  • 类型转换(如 Convert.ToInt32TryParse 失败的情况)

为什么要做: 反序列化/查询可能因数据格式错误、数据不存在等原因返回 null,后续访问其属性(如 eventInfo.Archive)会直接报错。

对应你代码的示例

// 反序列化后的对象校验(必须做)
if (eventInfo == null || string.IsNullOrWhiteSpace(eventInfo.Archive))
{
    LogTextHelper.Warn("物料分类新增失败:反序列化后的Archive数据为空");
    return;
}

如果不校验eventInfo 为 null 时,eventInfo.Archive 会触发空引用异常,中断业务流程。

3. 嵌套对象/多级属性访问前

适用场景

  • 访问对象的嵌套属性(如 dTOArchive.Name.ZhCN
  • 调用对象的方法(如 list.Add() 前,list 可能为 null)

为什么要做: C# 中多级属性访问时,只要其中一级为 null,就会抛出空引用异常。

对应你代码的示例

// 空值保护:防止 Name 为 null 导致 ZhCN 访问失败
info.TypeName = dTOArchive.Name?.ZhCN ?? string.Empty;

如果不做保护dTOArchive.Name 为 null 时,dTOArchive.Name.ZhCN 会直接报错。

4. 数据库/缓存操作前的关键数据校验

适用场景

  • 插入/更新数据库前,校验核心字段(如主键、必填字段)
  • 依赖其他数据的操作(如你代码中父级分类查询结果)

为什么要做: 核心字段为空会导致数据库操作失败(如主键为空、外键关联失败),依赖数据不存在会导致业务逻辑错误。

对应你代码的示例

// 父级分类查询结果校验(必须做)
if (p_info != null)
{
    info.ParentID = p_info.ID;
    info.ERPParentID = p_info.ERPID;
}
else
{
    string errorMsg = $"物料分类【{dTOArchive.Code}】父级数据不存在,父级ERPID:{dTOArchive.Parent}";
    LogTextHelper.Error(errorMsg);
    throw new Exception(errorMsg);
}

如果不校验p_info 为 null 时,p_info.ID 会报错,且会将无效的父级ID插入数据库,导致数据脏污。

5. 可选但建议做的场景

  • 集合类型(List/Array):访问 list.Count 前,校验 list != null
  • 可空值类型(int?/DateTime?):取值前校验 HasValue
  • 第三方组件/工具类返回值:如 File.ReadAllText 可能返回 null(文件不存在)

二、可以不做空值校验的场景(对比理解)

不是所有场景都需要校验,以下情况可省略:

  1. 内部可控的常量/初始化对象:如 var info = new MaterialTypeInfo(); 后,info 不可能为 null,无需校验。
  2. C# 8.0+ 的可空引用类型(Nullable Reference Types):通过 ! 操作符明确标记非空(如 name!),且代码经过严格静态检查。
  3. 单元测试中的 mock 数据:数据由你完全控制,且仅用于测试。

总结

  1. 核心原则:只要数据来源不受代码直接控制(外部入参、反序列化、数据库/第三方返回),或涉及多级属性访问,必须做空值校验。
  2. 校验目的:避免空引用异常、保障数据合法性、提前拦截错误(而非让程序崩溃)。
  3. 最佳实践:校验时不仅要判断 null,还要结合业务判断“无效值”(如空字符串、0值等,如你代码中的 string.IsNullOrWhiteSpace)。

到此这篇关于C#中空值校验应用场景分析的文章就介绍到这了,更多相关C#空值校验内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!

相关文章

  • c#通过进程调用cmd判断登录用户权限代码分享

    c#通过进程调用cmd判断登录用户权限代码分享

    最近自己开发软件需要读取本地配置文件,因为登录用户的权限不够会导致无法读取文件进而导致程序崩溃,查了一些解决方法,代码分享如下
    2013-12-12
  • C#后台调用WebApi接口的实现方法

    C#后台调用WebApi接口的实现方法

    本文主要介绍了C#后台调用WebApi接口的实现方法,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧
    2022-06-06
  • C#实现在两个数字之间生成随机数的方法

    C#实现在两个数字之间生成随机数的方法

    这篇文章主要介绍了C#实现在两个数字之间生成随机数的方法,在一些特殊场景会用到哦,需要的朋友可以参考下
    2014-08-08
  • C#中的值传递和引用传递详细解析

    C#中的值传递和引用传递详细解析

    本篇文章主要是对C#中的引用传递与值传递进行了详细的分析介绍,需要的朋友可以过来参考下,希望对大家有所帮助
    2014-01-01
  • WPF使用Accord实现屏幕录制功能

    WPF使用Accord实现屏幕录制功能

    这篇文章主要为大家详细介绍了WPF如何使用Accord实现屏幕录制,文中的示例代码讲解详细,对我们学习或工作有一定帮助,感兴趣的小伙伴可以了解一下
    2024-03-03
  • 详解C# Lazy Loading(延迟加载)

    详解C# Lazy Loading(延迟加载)

    这篇文章主要介绍了C# Lazy Loading(延迟加载)的相关资料,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下
    2021-04-04
  • 浅谈c# WPF中的PreviewTextInput

    浅谈c# WPF中的PreviewTextInput

    这篇文章主要介绍了浅谈c# WPF中PreviewTextInput的相关资料,帮助大家更好的理解和学习使用c#,感兴趣的朋友可以了解下
    2021-03-03
  • c# 线程安全队列的用法原理及使用示例

    c# 线程安全队列的用法原理及使用示例

    这篇文章主要介绍了c# 线程安全队列的用法原理及使用示例,帮助大家更好的理解和使用c#,感兴趣的朋友可以了解下
    2020-11-11
  • C#实现WinForm控件焦点的获取与失去

    C#实现WinForm控件焦点的获取与失去

    在一个数据输入表单中,当用户从一个文本框切换到另一个文本框时,需要准确地判断焦点的转移,以便进行数据验证、提示信息显示等操作,本文将探讨 Winform 控件获取与失去焦点的相关知识,需要的朋友可以参考下
    2025-01-01
  • 如何使用C#操作幻灯片

    如何使用C#操作幻灯片

    一般大家经常会用PPT遥控翻页笔来遥控幻灯片,本文确为大家介绍了使用C#制作一个遥控幻灯片,感兴趣的朋友可以参考下
    2015-07-07

最新评论