我不应该捕获哪些异常?

2023-12-20

我有一个运行长批处理过程的应用程序,其中可能会引发许多异常。如果在批次中的一项期间引发非关键异常,我想简单地记录它并继续,这样我们就可以稍后修复问题,同时让其他批次项目继续。

一些例外,例如OutOfMemoryException,对整个应用程序来说是毁灭性的,我想重新抛出这些,以便它们冒泡到全局异常处理程序,该处理程序将记录错误并停止应用程序。

所以我的问题是,是否有一个合理简短的关键异常列表,我可以在较低的异常处理程序中重新抛出这些异常,同时抑制(在记录之后)其他所有内容?

Thanks!

Edit:详细说明一下,这是我的程序的基本结构

foreach(var item in longItemList)
{
   try
   {
      bigDynamicDispatchMethod(item);
   }
   catch(Exception ex)
   {
      logException(ex);
   }
}

可能会引发大量异常,因为此循环几乎位于我的应用程序的顶层。我的项目中 99% 的代码都在调度方法后面。我在较低级别进行了合理的异常处理,但错误仍然存​​在,并且我不想在引发异常后停止批处理中的其他不相关进程。

尝试找出哪些异常可以在我的应用程序中的其他地方抛出似乎是一项艰巨的任务,而且似乎获取关键异常的黑名单会更简单。

有没有更好的方法来构建我的应用程序来处理这个问题?我愿意接受建议。


您不需要“不良”异常的列表,您应该默认将所有情况视为不良。只捕获您可以处理并从中恢复的内容。 CLRcan http://msdn.microsoft.com/en-us/library/system.appdomain.unhandledexception.aspx notify http://msdn.microsoft.com/en-us/library/system.windows.forms.application.threadexception.aspx未处理的异常,以便您可以适当地记录它们。吞并除黑名单异常之外的所有内容并不是修复错误的正确方法。那只会掩盖他们。读this http://msdn.microsoft.com/en-us/library/seyhszts.aspx and this http://msdn.microsoft.com/en-us/library/2w8f0bss.aspx.

出于目的进行捕获时不排除任何特殊例外 转移异常。

无需在 catch 子句中创建特殊异常列表, 你应该只捕获那些你可以合法捕获的异常 处理。您无法处理的异常不应被视为 非特定异常处理程序中的特殊情况。这 以下代码示例演示了对特殊情况的错误测试 异常以重新抛出它们。

public class BadExceptionHandlingExample2 {
    public void DoWork() {
        // Do some work that might throw exceptions.
    }
    public void MethodWithBadHandler() {
        try {
            DoWork();
        } catch (Exception e) {
            if (e is StackOverflowException ||
                e is OutOfMemoryException)
                throw;
            // Handle the exception and
            // continue executing.
        }
    }
}

其他一些规则:

通过捕获非特定异常来避免处理错误,例如 应用程序中的 System.Exception、System.SystemException 等 代码。在某些情况下,处理应用程序中的错误是 可以接受,但这种情况很少见。

应用程序不应处理可能导致的异常 意外或可利用的状态。如果你无法预测所有可能 异常原因并确保恶意代码无法利用 结果应用程序状态,您应该允许应用程序 终止而不是处理异常。

当您了解原因后,请考虑捕获特定的异常 将被抛出在给定的上下文中。

您应该只捕获那些可以恢复的异常。为了 例如,由于尝试打开而导致的 FileNotFoundException 一个不存在的文件可以由应用程序处理,因为它可以 将问题传达给用户并允许用户指定 不同的文件名或创建文件。打开文件的请求 生成 ExecutionEngineException 不应被处理,因为 无法在任何程度上了解异常的根本原因 确定性,并且应用程序无法确保安全 继续执行。

埃里克·利珀特 http://blogs.msdn.com/b/ericlippert/archive/2008/09/10/vexing-exceptions.aspx将所有异常分为 4 组:致命的、“愚蠢的”、令人烦恼的、外源性的。以下是我对埃里克建议的解读:

  Exc. type | What to do                          | Example
------------|-------------------------------------|-------------------
Fatal       | nothing, let CLR handle it          | OutOfMemoryException
------------|-------------------------------------|-------------------
Boneheaded  | fix the bug that caused exception   | ArgumentNullException
------------|-------------------------------------|-------------------
Vexing      | fix the bug that caused exception   | FormatException from 
            | (by catching exception  because     | Guid constructor
            | the framework provides no other way | (fixed in .NET 4.0 
            | way of handling). Open MS Connect   | by Guid.TryParse)
            | issue.                              | 
------------|-------------------------------------|-------------------
Exogenous   | handle exception programmatically   | FileNotFoundException 

这大致相当于微软的 https://rads.stackoverflow.com/amzn/click/com/0321545613分类:使用情况、程序错误和系统故障。 您还可以使用静态分析工具,例如FxCop https://stackoverflow.com/questions/2740738/fxcop-for-net-4-0实施some http://blogs.msdn.com/b/codeanalysis/archive/2006/06/14/faq_3a00_-why-does-fxcop-warn-against-catch_2800_exception_29003f00_-_2d00_-part-1-_5b00_nick-guerrera_5d00_.aspx这些规则。

本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系:hwhale#tublm.com(使用前将#替换为@)

我不应该捕获哪些异常? 的相关文章

  • 在结构中使用 typedef 枚举并避免类型混合警告

    我正在使用 C99 我的编译器是 IAR Embedded workbench 但我认为这个问题对于其他一些编译器也有效 我有一个 typedef 枚举 其中包含一些项目 并且我向该新类型的结构添加了一个元素 typedef enum fo
  • 秒表有最长运行时间吗?

    多久可以Stopwatch在 NET 中运行 如果达到该限制 它会回绕到负数还是从 0 重新开始 Stopwatch Elapsed返回一个TimeSpan From MSDN https learn microsoft com en us
  • 查找c中结构元素的偏移量

    struct a struct b int i float j x struct c int k float l y z 谁能解释一下如何找到偏移量int k这样我们就可以找到地址int i Use offsetof 找到从开始处的偏移量z
  • 从Web API同步调用外部api

    我需要从我的 Web API 2 控制器调用外部 api 类似于此处的要求 使用 HttpClient 从 Web API 操作调用外部 HTTP 服务 https stackoverflow com questions 13222998
  • BitTorrent 追踪器宣布问题

    我花了一点业余时间编写 BitTorrent 客户端 主要是出于好奇 但部分是出于提高我的 C 技能的愿望 我一直在使用理论维基 http wiki theory org BitTorrentSpecification作为我的向导 我已经建
  • 如何使用 ICU 解析汉字数字字符?

    我正在编写一个使用 ICU 来解析由汉字数字字符组成的 Unicode 字符串的函数 并希望返回该字符串的整数值 五 gt 5 三十一 gt 31 五千九百七十二 gt 5972 我将区域设置设置为 Locale getJapan 并使用
  • Clang 3.1 + libc++ 编译错误

    我已经构建并安装了 在前缀下 alt LLVM Clang trunk 2012 年 4 月 23 日 在 Ubuntu 12 04 上成功使用 GCC 4 6 然后使用此 Clang 构建的 libc 当我想使用它时我必须同时提供 lc
  • 不同枚举类型的范围和可转换性

    在什么条件下可以从一种枚举类型转换为另一种枚举类型 让我们考虑以下代码 include
  • 在 ASP.NET 5 中使用 DI 调用构造函数时解决依赖关系

    Web 上似乎充斥着如何在 ASP NET 5 中使用 DI 的示例 但没有一个示例显示如何调用构造函数并解决依赖关系 以下只是众多案例之一 http social technet microsoft com wiki contents a
  • C# 中通过 Process.Kill() 终止的进程的退出代码

    如果在我的 C 应用程序中 我正在创建一个可以正常终止或开始行为异常的子进程 在这种情况下 我通过调用 Process Kill 来终止它 但是 我想知道该进程是否已退出通常情况下 我知道我可以获得终止进程的错误代码 但是正常的退出代码是什
  • C#中如何移动PictureBox?

    我已经使用此代码来移动图片框pictureBox MouseMove event pictureBox Location new System Drawing Point e Location 但是当我尝试执行时 图片框闪烁并且无法识别确切
  • 显示UnityWebRequest的进度

    我正在尝试使用下载 assetbundle统一网络请求 https docs unity3d com ScriptReference Networking UnityWebRequest GetAssetBundle html并显示进度 根
  • 如何设计以 char* 指针作为类成员变量的类?

    首先我想介绍一下我的情况 我写了一些类 将 char 指针作为私有类成员 而且这个项目有 GUI 所以当单击按钮时 某些函数可能会执行多次 这些类是设计的单班在项目中 但是其中的某些函数可以执行多次 然后我发现我的项目存在内存泄漏 所以我想
  • 控件的命名约定[重复]

    这个问题在这里已经有答案了 Microsoft 在其网站上提供了命名指南 here http msdn microsoft com en us library xzf533w0 VS 71 aspx 我还有 框架设计指南 一书 我找不到有关
  • 为什么编译时浮点计算可能不会得到与运行时计算相同的结果?

    In the speaker mentioned Compile time floating point calculations might not have the same results as runtime calculation
  • 如何在Xamarin中删除ViewTreeObserver?

    假设我需要获取并设置视图的高度 在 Android 中 众所周知 只有在绘制视图之后才能获取视图高度 如果您使用 Java 有很多答案 最著名的方法之一如下 取自这个答案 https stackoverflow com a 24035591
  • C# 成员变量继承

    我对 C 有点陌生 但我在编程方面有相当广泛的背景 我想做的事情 为游戏定义不同的 MapTiles 我已经像这样定义了 MapTile 基类 public class MapTile public Texture2D texture pu
  • 测试用例执行完成后,无论是否通过,如何将测试用例结果保存在变量中?

    我正在使用 NUNIT 在 Visual Studio 中使用 Selenium WebDriver 测试用例的代码是 我想在执行测试用例后立即在变量中记录测试用例通过或失败的情况 我怎样才能实现这一点 NUnit 假设您使用 NUnit
  • 是否可以在 .NET Core 中将 gRPC 与 HTTP/1.1 结合使用?

    我有两个网络服务 gRPC 客户端和 gRPC 服务器 服务器是用 NET Core编写的 然而 客户端是托管在 IIS 8 5 上的 NET Framework 4 7 2 Web 应用程序 所以它只支持HTTP 1 1 https le
  • Windows 和 Linux 上的线程

    我在互联网上看到过在 Windows 上使用 C 制作多线程应用程序的教程 以及在 Linux 上执行相同操作的其他教程 但不能同时用于两者 是否存在即使在 Linux 或 Windows 上编译也能工作的函数 您需要使用一个包含两者的实现

随机推荐