Loading [MathJax]/jax/output/CommonHTML/config.js
前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >专栏 >C#中烦人的Null值判断竟然这样就被消灭了

C#中烦人的Null值判断竟然这样就被消灭了

作者头像
依乐祝
发布于 2020-12-28 03:50:52
发布于 2020-12-28 03:50:52
1.3K00
代码可运行
举报
文章被收录于专栏:依乐祝依乐祝
运行总次数:0
代码可运行

Null值检查应该算是开发中最常见且烦人的工作了吧,有人反对吗?反对的话请右上角关门不送。这篇文章就教大家一招来简化这个烦人又不可避免的工作。

罗嗦话不多说,先看下面一段简单的不能再简单的null值判断代码:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public void DoSomething(string message)
{
  if(message == null)
    throw new ArgumentNullException();
    
    // ...
}

方法体的每个参数都将用if语句进行检查,并逐个抛出 ArgumentNullException 的异常。

关注我的朋友,应该看过我上篇《一个小技巧助您减少if语句的状态判断》的文章,它也是简化Null值判断的一种方式。简化后可以如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public void DoSomething(string message)
{
  Assert.That<ArgumentNullException>(message == null, nameof(DoSomething));
    // ...
}

但是还是很差强人意。

**

NotNullAttribute

这里你可能想到了 _System.Diagnostics.CodeAnalysis_ 命名空间下的这个 NotNull 特性。这不会在运行时检查任何内容。它只适用于CodeAnalysis,并在编译时而不是在运行时发出警告或错误!

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public void DoSomething([NotNull]string message) // Does not affect anything at runtime.
{
}

public void AnotherMethod()
{
  DoSomething(null); // MsBuild doesn't allow to build.
  string parameter = null;
  DoSomething(parameter); // MsBuild allows build. But nothing happend at runtime.
}

自定义解决方案

这里我们将去掉用于Null检查的if语句。如何处理csharp中方法参数的赋值?答案是你不能!. 但你可以使用另一种方法来处理隐式运算符的赋值。让我们创建 NotNull<T> 类并定义一个隐式运算符,然后我们可以处理赋值。

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public class NotNull<T>
{
    public NotNull(T value)
    {
        this.Value = value;
    }

    public T Value { get; set; }

    public static implicit operator NotNull<T>(T value)
    {
        if (value == null)
            throw new ArgumentNullException();
        return new NotNull<T>(value);
    }
}

现在我们可以使用NotNull对象作为方法参数.

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
static void Main(string[] args)
{
  DoSomething("Hello World!"); // Works perfectly ?
  
  DoSomething(null); // Throws ArgumentNullException at runtime.
  
  string parameter = null;
  DoSomething(parameter); // Throws ArgumentNullException at runtime.
}

public static void DoSomething(NotNull<string> message) // <--- NotNull is used here
{
    Console.WriteLine(message.Value);
}

如您所见, DoSomething() 方法的代码比以前更简洁。也可以将NotNull类与任何类型一起使用,如下所示:

代码语言:javascript
代码运行次数:0
运行
AI代码解释
复制
public void DoSomething(NotNull<string> message, NotNull<int> id, NotNull<Product> product)
{
  // ...
}

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2020-12-25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
暂无评论
推荐阅读
编辑精选文章
换一批
计算机视觉学术速递[7.21]
访问www.arxivdaily.com获取含摘要速递,涵盖CS|物理|数学|经济|统计|金融|生物|电气领域,更有搜索、收藏、发帖等功能!点击阅读原文即可访问 cs.CV 方向,今日共计45篇 Tr
公众号-arXiv每日学术速递
2021/07/27
1.7K0
计算机视觉学术速递[9.6]
【1】 Semantic Segmentation on VSPW Dataset through Aggregation of Transformer Models 标题:基于Transformer模型聚合的VSPW数据集语义分割 链接:https://arxiv.org/abs/2109.01316
公众号-arXiv每日学术速递
2021/09/16
5270
计算机视觉学术速递[9.1]
【1】 Detecting Mitosis against Domain Shift using a Fused Detector and Deep Ensemble Classification Model for MIDOG Challenge 标题:基于融合检测器和深度集成分类模型的MIDOG挑战有丝分裂检测 链接:https://arxiv.org/abs/2108.13983
公众号-arXiv每日学术速递
2021/09/16
9860
计算机视觉学术速递[8.30]
【1】 Evaluating Transformer based Semantic Segmentation Networks for Pathological Image Segmentation 标题:基于Transformer的语义分割网络在病理图像分割中的评价 链接:https://arxiv.org/abs/2108.11993
公众号-arXiv每日学术速递
2021/09/16
7690
计算机视觉学术速递[6.25]
【1】 Video Swin Transformer 标题:视频双Transformer
公众号-arXiv每日学术速递
2021/07/02
1.3K0
计算机视觉学术速递[6.28]
【1】 PVTv2: Improved Baselines with Pyramid Vision Transformer 标题:PVTv2:使用金字塔视觉Transformer改进基线
公众号-arXiv每日学术速递
2021/07/02
1.4K0
计算机视觉学术速递[6.18]
【1】 XCiT: Cross-Covariance Image Transformers 标题:XCiT:互协方差图像转换器
公众号-arXiv每日学术速递
2021/07/02
1.6K0
计算机视觉与模式识别学术速递[11.10]
【1】 Sliced Recursive Transformer 标题:片式递归Transformer 链接:https://arxiv.org/abs/2111.05297
公众号-arXiv每日学术速递
2021/11/17
8900
计算机视觉学术速递[9.8]
【1】 nnFormer: Interleaved Transformer for Volumetric Segmentation 标题:nnFormer:用于体积分割的交错Transformer 链接:https://arxiv.org/abs/2109.03201
公众号-arXiv每日学术速递
2021/09/16
2.1K0
计算机视觉学术速递[7.12]
【1】 ViTGAN: Training GANs with Vision Transformers 标题:ViTGAN:用视觉Transformer训练Gan
公众号-arXiv每日学术速递
2021/07/27
1.5K0
计算机视觉学术速递[6.21]
【1】 End-to-end Temporal Action Detection with Transformer 标题:基于Transformer的端到端时间动作检测
公众号-arXiv每日学术速递
2021/07/02
1.3K0
计算机视觉学术速递[8.20]
【1】 PoinTr: Diverse Point Cloud Completion with Geometry-Aware Transformers 标题:PoinTr:使用几何感知转换器完成不同的点云 链接:https://arxiv.org/abs/2108.08839
公众号-arXiv每日学术速递
2021/08/24
1.6K0
计算机视觉与模式识别学术速递[11.11]
【1】 Multimodal Transformer with Variable-length Memory for Vision-and-Language Navigation 标题:用于视觉和语言导航的变长记忆多模转换器 链接:https://arxiv.org/abs/2111.05759
公众号-arXiv每日学术速递
2021/11/17
1K0
计算机视觉与模式识别学术速递[12.22]
【1】 iSegFormer: Interactive Image Segmentation with Transformers 标题:iSegFormer:基于Transformers的交互式图像分割 链接:https://arxiv.org/abs/2112.11325
公众号-arXiv每日学术速递
2021/12/24
1.6K0
计算机视觉学术速递[7.28]
【1】 Exploring Sequence Feature Alignment for Domain Adaptive Detection Transformers 标题:基于域自适应检测Transformer的序列特征比对研究
公众号-arXiv每日学术速递
2021/07/29
2.2K0
计算机视觉学术速递[8.23]
【1】 Trans4Trans: Efficient Transformer for Transparent Object and Semantic Scene Segmentation in Real-World Navigation Assistance 标题:Trans4Trans:真实导航辅助中透明对象和语义场景分割的高效转换器 链接:https://arxiv.org/abs/2108.09174
公众号-arXiv每日学术速递
2021/08/24
2K0
计算机视觉学术速递[8.19]
【1】 Boosting Salient Object Detection with Transformer-based Asymmetric Bilateral U-Net 标题:基于Transformer的非对称双边U网增强显著目标检测 链接:https://arxiv.org/abs/2108.07851
公众号-arXiv每日学术速递
2021/08/24
1.7K0
计算机视觉学术速递[8.18]
【1】 Light Field Image Super-Resolution with Transformers 标题:用Transformer实现光场图像的超分辨率 链接:https://arxiv.org/abs/2108.07597
公众号-arXiv每日学术速递
2021/08/24
2.1K0
计算机视觉与模式识别学术速递[12.10]
【1】 BLT: Bidirectional Layout Transformer for Controllable Layout Generation 标题:BLT:可控版图生成的双向版图转换器 链接:https://arxiv.org/abs/2112.05112
公众号-arXiv每日学术速递
2021/12/10
1.6K0
计算机视觉学术速递[6.24]
【1】 Transformer Meets Convolution: A Bilateral Awareness Net-work for Semantic Segmentation of Very Fine Resolution Ur-ban Scene Images 标题:Transform Meets卷积:一种用于超细分辨率URBAN场景图像语义分割的双边感知网络
公众号-arXiv每日学术速递
2021/07/02
1.7K0
相关推荐
计算机视觉学术速递[7.21]
更多 >
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档
本文部分代码块支持一键运行,欢迎体验
本文部分代码块支持一键运行,欢迎体验