首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

NullReferenceException,就不应该存在!

2017-11-29 16:08 如果要你说出 .NET 中的三个异常,NullReferenceException 一定会成为其中一个;如果说出 .NET 中的一个异常,NullReferenceException...---- NullReferenceException 的可恨之处 你说 NullReferenceException 可以告诉你程序中某个字段为 null,告诉你程序发生了 BUG。...异常就是要提供足够我们诊断错误的信息,让我们在开发中避免发生这样的错误。...所以,为了解决这些困惑,我建议在开发中以如下方式对待我们的 null: 对任何可被外部模块调用的方法的参数进行 null 判断,并在参数为 null 时抛出 ArgumentNullException。...不要在方法中返回 null。如果你无法根据现有状态完成方法承诺的任务,请抛出具体的异常并给出真实的原因。

1.1K10

C# 可为空引用类型

尽管如此,就目前而言,即使在 C# 版本 7 发布后,此语言也仍称不上完美。我这里指的是,尽管有理由期望 C# 会一直不断添加新功能,但遗憾的是,同时也存在着一些问题。...导致可为空引用类型不尽理想的一些原因在于: 对空值调用成员会导致 System.NullReferenceException 异常抛出,导致生产代码抛出 System.NullReferenceException...不过,在 C# 8.0 中,C# 语言团队正开始着手改进此问题。...减少 NullReferenceException 抛出:降低 NullReferenceException 异常抛出的可能性,具体是通过改进静态流分析,标记出可能存在问题的情况,即调用值成员之一前未显式检查值是否为空...请注意,必须有相应的框架版本,才能使用此功能(自 C# 2.0 和通用支持发布起就没有此要求)。 扩展渗透到方方面面:LINQ 引入了扩展方法。

19120
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    C#开发人员应该知道的13件事情

    使用工具可以帮助你在发布之后,解决掉一些问题。 编码标准 遵照编码标准可以编写出更多可维护的代码,特别是在由多个开发人员或团队编写和维护的代码库中。...不计其它后果地处理当前异常只会使问题难以识别和调试。 对于公开了工作API的代码来说,将异常包含于自定义异常中,是特别有用的。异常是方法的可见接口的一部分,应该与参数和返回值一起被控制。...可能导致更多异常的方法,是不应该被使用在可维护解决方案中的。 抛出和重新抛出异常 当你希望在更深层次处理一个捕获到的异常时,维护原始异常状态和堆栈对于调试有极大的帮助。...小心使用DebuggerStepThrough属性,如果应用了这个属性,会导致很难在方法中找到bug,因为你不能单步执行或打断它们! 9. 调试 调试是任何开发工作中重要的组成部分。...静态和动态分析工具可以帮助你在发布代码之前识别潜在的NullReferenceException异常。在C#中,空引用通常由尚未引用对象的变量引起。对于空值类型和引用类型来说,Null是一个有效值。

    2.3K90

    使用 Moq 测试.NET Core 应用 -- Mock 方法

    上一篇文章, 我在单元测试的时候, 把依赖项设为null: ? 然后便出现了NullReferenceException, 导致测试无法正常运行....首先应该做的是在TransferApproval的构造函数里判断参数是否为null, 如果为null的话应该抛出ArgumentNullException: ? 这是更恰当的异常....这样的话, 在测试的时候, 抛出的就是ArgumentNullException了, 它可以更恰当的表达程序出现的问题: ? 现在我们可以使用mock版本的依赖项来代替null了: ?...让我们来调试一下这个测试, 我在TransferApproval类里面设置一个端点, 查看一下这个mock依赖项的方法返回值: ? 然后调试测试: ? 跑到断点 ?...MockBehavior是一个枚举, 它有三个值: MockBehavior.Strict, 如果mock对象上的方法没有被预先设置好, 那么测试中调用该方法的时候就会抛出异常.

    2.4K40

    .NET基础拾遗(2)面向对象的实现和异常的处理基础

    隐藏则是指子类用new关键字重新实现定义在基类中的方法,但在实际运行时只能根据引用来调用相应的方法。   ...大家都知道,通常在编译程序时可以选择Bebug版本还是Release版本,编译器将会根据”调试“和”发布“两个不同的出发点去编译程序。...在Debug版本中,所有Debug类的断言(Assert)语句都会得到保留,相反在Release版本中,则会被通通删除。这样的机制有助于我们编写出方便调试同时又不影响正式发布的程序代码。   ...Conditional特性用于编写在某个特定版本中运行的方法,通常它编写一些在Debug版本中支持测试的方法。当版本不匹配时,编译器会把Conditional特性的方法内容置为空。   ...异常是一种耗费资源的机制,每当异常被抛出时,异常堆栈将会被建立,异常信息将被加载,而通常这些工作的成本相对较高,并且在尝试性类型转换时,这些信息都没有意义。

    61710

    WPF 支持的多线程 UI 并不是线程安全的

    例如用来显示启动闪屏的 UI 线程 两个线程的话你需要大量重复试验才能复现;而创建更多线程可以大大提高单次复现概率 这些 UI 线程都显示 WPF 窗口 无论是 .NET Framework 4.7.2 版本的...WPF,还是 .NET Core 3 版本的 WPF 都会出现此问题 现象: 抛出异常,程序崩溃 比如下面是其中一种异常: Exception thrown: 'System.NullReferenceException...System.NullReferenceException: Object reference not set to an instance of an object....WPF 中在 Visual Studio 2019 抓到的异常: 复现步骤 创建一个新的 WPF 项目(无论是 .NET Framework 4.7.2 还是 .NET Core 3) 保持自动生成的...创建一个新的包含 Main 函数的 Program 类,并在项目属性中设置 Program 为启动对象(替代 App)。

    47320

    一文看懂 .NET 的异常处理机制、原则以及最佳实践

    如果你准备抛出异常,在这个信息里面记录能帮助调试问题的详细文字信息。...Data 这是一个字典,可以存放基于键值的任意数据,帮助在异常信息中获得更多可以用于调试的数据 HelpLink 这是一个 url,这个 url 里可以提供大量用于说明此异常原因的信息 如果你自己写一个自定义异常类...然而大多数情况下我们都考虑使用 .NET 中自带的异常类,因此可以充分利用 Exception 类中的已有属性在特殊情况下报告更详细的利于调试的异常信息。...暂时请勿使用 实现错误: 前面由 CLR 抛出的异常代码主要都是实现错误 NullReferenceException 试图在空引用上执行某些方法,除了告诉实现者出现了意料之外的 null 之外,没有什么其它价值了...如果要解决问题,需要从非托管代码中着手调查。 这个异常是访问了不允许的内存时引发的。在原因上会类似于托管中的 NullReferenceException。

    88241

    基础:C# try catch finally异常处理(Exception)

    C# 中try块可以捕获测试代码块中的错误。catch块可以处理错误。finally块无论是否try和catch块出现异常都可以执行代码。...InvalidOperationException 方法的调用时间错误 MethodAccessException 试图访问思友或者受保护的方法 MissingMemberException 访问一个无效版本的...DLL NotFiniteNumberException 对象不是一个有效的成员 NotSupportedException 调用的方法在类中没有实现 NullReferenceException 试图使用一个未分配的引用...NullReferenceException 当一个空对象被引用时运行时引发。 InvalidOperationException 当对方法的调用对对象的当前状态无效时,由某些方法引发。...InteropException 目标在或发生在CLR外面环境中的异常的基类。 ComException 包含COM类的HRESULT信息的异常。

    17610

    ASP.NET Core | 笔记

    ASP.NET Core 中 启用跨域 参考: 在 ASP.NET CORE 中 (CORS) 跨 ASP.NET Core | Microsoft Docs 同一源 如果两个 URL 具有相同的方案、...请参阅此处的版本兼容性表。 或者,您可以尝试切换到Pomelo.EntityFrameworkCore.MySql 5.0.0-alpha.2(或更高版本);请参阅其兼容包版本表。...NuGet 符号包 | Microsoft Docs 让你发布的nuget包支持源代码调试 - czd890 - 博客园 良好的调试体验依赖于调试符号的存在,因为它们提供了一些关键信息,例如已编译的代码与源代码之间的关联...还可以通过以下项目属性在 dll 或 exe 中 embed 它们:embedded 创建符号包 如果使用 dotnet CLI 或 MSBuild,则除...当前文件夹中必须同时有 .nupkg 和 .snupkg 文件。 nuget push MyPackage.nupkg NuGet 会将两个包发布到 nuget.org。

    4.7K20

    try-catch-when 中如果 when 语句抛出异常,程序将彻底崩溃

    在 .NET Framework 4.8 中,try-catch-when 中如果 when 语句抛出异常,程序将彻底崩溃。而 .NET Core 3.0 中不会出现这样的问题。...对其解引用会产生 NullReferenceException。很显然代码不应该这么写,但可以用来验证 catch-when 语句的行为。 按照官网描述,输出应该为 Try-Catch 2-End。...在 .NET Core 3.0 中的行为和 .NET Framework 4.8 中的行为 下面两张图分别是这段代码在 .NET Core 3.0 和 .NET Framework 4.8 中的输出:...如果我们以 Visual Studio 调试启动此程序,可以看到抛出了 CLR 异常: 以下是在 Visual Studio 中单步跟踪的步骤: Issue 和行为 由于本人金鱼般的记忆力,我竟然给微软报了三次这个...欢迎转载、使用、重新发布,但务必保留文章署名 吕毅 (包含链接: https://blog.walterlv.com ),不得用于商业目的,基于本文修改后的作品务必以相同的许可发布。

    22720

    拥抱.NET Core系列:Logging (1)

    在之前我们简单介绍了 .NET Core 中的 DI组件,没来及了解的童鞋可以翻翻我之前的文章。 接下来会对 .NET Core 中的 Logging 进行介绍。...默认情况下禁用这些消息,并且不应在生产环境中启用这些消息。 Debug 在开发过程中用于交互式调查的日志。这些日志应主要包含对调试有用的信息,不具有长期价值。...这句话肯定是对的,但在遍地DI的项目中 Logger 很有可能被开发者传入null,这时候就会影响业务的执行,那么这时候 NullLogger 非常适合做那个最糟糕的实现者。...用来替换日志记录或防止“NullReferenceException”这类异常的发生。 非常可惜的是,1.1.3版本中没有提供 NullLogger 这样的实现。...可以看到在没有添加 Logging 组件的时候日志记录也不会抛出异常。 ps:NullLogger 摘抄至.NET Standard2.0中的 NullLoggerOfT.cs。

    66311

    .NET不可变集合已经正式发布

    微软基础类库(Base Class Library)团队已经完成了.NET不可变集合的正式版本,但不包括ImmutableArray。与其一起发布的还包括针对其它不可变对象类型的设计指南。...如果你需要在多个线程中安全地共享集合,并且允许每个线程在需要时对其内容进行改变。这种场景就是不可变集合所设计的初衷。...WithLines(Lines.Replace(oldValue, newValue)); } } ImmutableArray被移除 由于性能方面的原因,ImmutableArray从最终的发布版本中被移除...因此,AddRange方法的实现会因为NullReferenceException的产生而崩溃。...由于这种接口引用是非空的,使用者在调用它的方法或者属性时不会考虑到有可能产生NullReferenceException。

    884100

    未将对象引用设置到对象的实例–可能出现的问题总结

    ,或直接用response.write()输出所取的变量值   (2)查看代码中是否存在未初始化的变量 三、 SqlConnection.Open   未将对象引用设置到对象的实例 在使用VS2003...异常具体信息: System.NullReferenceException: 未将对象引用设置到对象的实例。 源错误: 。。。。...conn.Open(); …… 跟踪调试也肯定能够确定 对conn进行new 操作 可是程序常常在这个地方报错,可是有时候重新启动server或者重新启动IIS有能正常使用了。...六、 我碰到的问题是,无意重置了DataSet引用,后出现这个问题,请大家好好查查自己的代码,是不是在其它地方又一次引用了,在我的程序中DataSet被设置成全局对象。...发布者:全栈程序员栈长,转载请注明出处:https://javaforall.cn/119126.html原文链接:https://javaforall.cn

    3.4K30

    【翻译】.NET Core3.1发布

    最重要的是.NET Core 3.1是长期支持(LTS)版本,并且将支持三年。和过去一样,我们希望花一些时间来发布下一个LTS版本。...发行说明: .NET Core 3.1发行说明 .NET Core 3.1问题的GitHub问题 GitHub发布 .NET Core 3.1中的更改主要集中在Blazor和Windows Desktop...它还包含对的支持LangVersion,并nameof在预览中附带并打开了静态类。F#核心库现在还针对.NET Standard 2.0。您可以在发布F#4.7中阅读更多内容。....NET Core已针对Docker进行了强化,以使.NET应用程序在容器中可预测且有效地工作。已将容器配置为有限的内存或CPU时,垃圾收集器和线程池已更新为更好地工作。....如果您使用的是我们在应用程序中删除的控件,则会看到构建中断。另外,如果在最新版本的.NET Core Windows窗体设计器中打开.NET Core 3.0应用程序,则在使用这些控件时会看到错误。

    1.5K40

    Visual Studio 调试系列9 调试器提示和技巧

    02 编辑代码并继续调试 (C#,VB, C++) 在 Visual Studio 支持的大多数语言中,你都可以在调试会话的过程中编辑代码,然后继续调试。...在下图中,调试器会在发生 System.NullReferenceException 时中断代码。 有关详细信息,请参阅管理异常。 ?...在源代码中显示线程 调试时,单击源中显示线程按钮 ? 中调试工具栏。 查看窗口左侧的滚动条。 在这一行,你可以看到线程标记图标 ? ,类似于两根细线。线程标记指示线程在此位置停止。...12 将调试器附加到您的应用程序 若要附加到正在运行的应用,调试器将加载为想要调试的应用的相同内部版本生成的符号 (.pdb) 文件。 在某些情况下,了解符号文件的一些知识非常有用。...有时,应用开发人员发布的应用不包含匹配的符号文件 (为了减少占用的空间),但会为内部版本保留一份匹配的符号文件,用于以后调试发布版本。 了解如何调试器如何区分用户代码,请参阅仅我的代码。

    3.2K10

    【翻译】.NET Core3.1发布

    最重要的是.NET Core 3.1是长期支持(LTS)版本,并且将支持三年。和过去一样,我们希望花一些时间来发布下一个LTS版本。...发行说明: .NET Core 3.1发行说明 .NET Core 3.1问题的GitHub问题 GitHub发布 .NET Core 3.1中的更改主要集中在Blazor和Windows Desktop...它还包含对的支持LangVersion,并nameof在预览中附带并打开了静态类。F#核心库现在还针对.NET Standard 2.0。您可以在发布F#4.7中阅读更多内容。....NET Core已针对Docker进行了强化,以使.NET应用程序在容器中可预测且有效地工作。已将容器配置为有限的内存或CPU时,垃圾收集器和线程池已更新为更好地工作。....如果您使用的是我们在应用程序中删除的控件,则会看到构建中断。另外,如果在最新版本的.NET Core Windows窗体设计器中打开.NET Core 3.0应用程序,则在使用这些控件时会看到错误。

    1.4K10

    .NET Core 网络数据采集 -- 使用AngleSharp做html解析

    其中DOM是和AngleSharp里的类这样对应的: 这个图其实是老一点的版本, 新版本的DOM模型是稍微有点不同的, 不过你只要理解这个意思就行......Console.WriteLine("Message :{0} ", e.Message); } } 但是即使网页获取成功了, 网页上的内容也并非完全是我们所期待的, 仍可能会抛出异常...HttpRequestException)}: {e.Message}"); return null; } } CSS是网络爬虫的福音, 下面这两个元素在页面中可能会出现很多次...由于同时支持CSS选择器和Linq, 所以抽取元素的工作简单多了. 导航树 一个页面, 它的结构可以是这样的: 这里面有几个概念: 子标签和后代标签....与浅网对立的就是深网 deep web: 互联网中90%都是深网. 暗网Darknet / dark web / dark internet: 它完全是另外一种怪兽.

    4.3K00

    C#一分钟浅谈:ReSharper 插件增强开发效率

    在现代软件开发中,提高开发效率是每个开发者追求的目标之一。...安装与配置安装 ReSharper 非常简单,只需在 Visual Studio 中通过扩展管理器搜索并安装即可。安装完成后,ReSharper 会自动检测项目中的代码问题,并提供相应的修复建议。...name 可能为空,调用 Length 属性可能导致 NullReferenceException。2....(Exception ex) { Console.WriteLine(ex.Message); } }}ReSharper 提示:catch 块中没有重新抛出异常或记录日志...在实际开发中,合理利用 ReSharper 的功能,不仅可以提高代码质量,还能减少调试时间,让开发过程更加高效和愉快。希望本文的内容能为你的 C# 开发之旅带来一些启发和帮助。

    24610
    领券