信息
您所需的主题如下所示。但此主题未包含在此库中。

Exception 类

2013/12/13

表示在应用程序执行过程中发生的错误。

System.Object
  System.Exception
    更多...

Namespace:  System
程序集:  mscorlib(位于 mscorlib.dll 中)

public class Exception

Exception 类型公开以下成员。

  名称说明
公共方法Exception()初始化 Exception 类的新实例。
公共方法Exception(String)使用指定错误消息初始化 Exception 类的新实例。
公共方法Exception(String, Exception)使用指定错误消息和对导致此异常的内部异常的引用来初始化 Exception 类的新实例。
返回顶部

  名称说明
公共属性Data获取一个提供用户定义的其他异常信息的键/值对的集合。
公共属性HelpLink获取或设置指向此异常所关联帮助文件的链接。
公共属性HResult获取或设置 HRESULT(一个分配给特定异常的编码数字值)。
公共属性InnerException获取导致当前异常的 Exception 实例。
公共属性Message获取描述当前异常的消息。
公共属性Source获取或设置导致错误的应用程序或对象的名称。
公共属性StackTrace获取在引发当前异常时调用堆栈上帧的字符串表示形式。
返回顶部

  名称说明
公共方法Equals(Object)确定指定的 Object 是否等于当前的 Object (从 Object 继承。)
受保护的方法Finalize允许 Object 在垃圾回收器回收该对象之前尝试释放资源并执行其他清理操作。 (从 Object 继承。)
公共方法GetBaseException当在派生类中重写时,返回 Exception,它是一个或多个并发的异常的根源。
公共方法GetHashCode用作特定类型的哈希函数。 (从 Object 继承。)
公共方法GetType获取当前实例的运行时类型。
受保护的方法MemberwiseClone创建当前 Object 的浅表副本。 (从 Object 继承。)
公共方法ToString创建并返回当前异常的字符串表示形式。 (重写 Object.ToString()。)
返回顶部

此类是所有异常的基类。当发生错误时,系统或当前执行的应用程序将通过引发包含错误信息的异常来报告该错误。引发异常之后,将由应用程序或默认异常处理程序处理该异常。

Try-Catch 块

公共语言运行时提供一种异常处理模型,该模型基于对象形式的异常表示形式,并且将程序代码和异常处理代码分到 try 块和 catch 块中。可以有一个或多个 catch 块,每个块都设计为处理一种特定类型的异常,或者将一个块设计为捕捉比其他块更具体的异常。

如果应用程序将处理在执行应用程序代码块期间发生的异常,则代码必须放置在 try 语句中。try 语句中的应用程序代码是 try 块。处理由 try 块引发的异常的应用程序代码放在 catch 语句中,称为 catch 块。零个或多个 catch 块与一个 try 块相关联,每个 catch 块均包含一个确定该块处理的异常类型的类型筛选器。

try 块中出现异常时,系统按所关联 catch 块在应用程序代码中出现的顺序搜索它们,直到定位到处理该异常的 catch 块为止。如果某 Catch 块的类型筛选器指定 T 或任何派生出 T 的类型,则该 catch 块处理 T 类型的异常。系统在找到第一个处理该异常的 catch 块后即停止搜索。因此,正如本节后面的示例所演示的那样,在应用程序代码中处理某类型的 catch 块必须在处理其基类型的 catch 块之前指定。处理 System.Exception 的 Catch 块最后指定。

如果当前 try 块所关联的所有 try 块均不处理该异常,且当前 try 块嵌套在当前调用的其他 try 块中,则搜索与下一个封闭 try 块相关联的 catch 块。如果没有找到用于该异常的 catch 块,则系统搜索当前调用中前面的嵌套级别。如果在当前调用中没有找到用于该异常的 catch 块,则将该异常沿调用堆栈向上传递,搜索上一个堆栈帧来查找处理该异常的 catch 块。继续搜索调用堆栈,直到该异常得到处理或调用堆栈中没有更多的帧为止。如果到达调用堆栈顶部却没有找到处理该异常的 catch 块,则由默认的异常处理程序处理该异常,然后应用程序终止。

异常类型的功能

异常类型支持下面的功能:

  • 描述错误的可读文本。当异常发生时,运行时产生文本消息通知用户错误的性质并提供解决该问题的操作建议。此文本消息保存在异常对象的 Message 属性中。在创建异常对象过程中,可以将文本字符串传递给构造函数以描述该特定异常的详细信息。如果没有向构造函数提供错误消息参数,则将使用默认错误消息。

  • 发生异常时调用堆栈的状态。StackTrace 属性包含可以用来确定代码中错误发生位置的堆栈跟踪。堆栈跟踪列出所有调用的方法和源文件中这些调用所在的行号。

异常类型的类别

基类 Exception 下存在两类异常:

异常类属性

Exception 包含许多属性,可帮助您识别异常的代码位置、类型、帮助文件和原因:StackTraceInnerExceptionMessageHResultData

当在两个或多个异常之间存在因果关系时,InnerException 属性会维护此信息。作为对此内部异常的反应将引发外部异常。处理外部异常的代码可利用以前的内部异常的信息更妥当地处理错误。关于异常的补充信息可以存储在 Data 属性中。

应本地化在创建异常对象过程中传递给构造函数的错误消息字符串,这种字符串可以使用 ResourceManager 从资源文件提供。

Exception 使用具有值 0x80131500 的 HRESULT COR_E_EXCEPTION。

有关 Exception 实例的初始属性值列表,请参见 Exception 构造函数。

性能注意事项

引发或处理异常时,将使用大量的系统资源和执行时间。引发异常只是为了处理确实异常的情况,而不是为了处理可预知的事件或流控制。例如,如果方法参数无效,而应用程序需要使用有效的参数调用方法,则可以引发异常。无效的方法参数意味着出现了异常情况。相反,用户偶尔会输入无效数据,这是可以预见的,因此如果用户输入无效,则不要引发异常。在这种情况下,请提供重试机制以便用户输入有效输入。

仅对特别条件引发异常,然后在应用于大多数应用程序的常规异常处理程序中捕捉异常,而不是在应用于特定异常的处理程序中捕捉异常。此方法的基础在于,大多数错误都可以通过验证以及与错误接近的错误处理代码进行处理;不需要引发和捕捉异常。通用目的异常处理程序捕捉的是在应用程序任意位置引发的、真正不可预期的异常。

此外,返回代码正常时不要引发异常;不要将返回代码转换为异常;也不要例行公事地捕捉异常、忽略异常,然后继续处理。

下面的代码示例说明如何定义 catch 块来处理 ArithmeticException 错误。此 catch 块还捕捉 DivideByZeroException 错误,因为 DivideByZeroExceptionArithmeticException 派生,且没有为 DivideByZeroException 错误显式定义 catch 块。

说明注意:

要运行此示例,请参见生成具有静态 Windows Phone TextBlock 控件的示例


using System;

class Example
{
   public static void Demo(System.Windows.Controls.TextBlock outputBlock)
   {
      int x = 0;
      try
      {
         int y = 100 / x;
      }
      catch (ArithmeticException e)
      {
         outputBlock.Text += String.Format("ArithmeticException Handler: {0}", e.ToString()) + "\n";
      }
      catch (Exception e)
      {
         outputBlock.Text += String.Format("Generic Exception Handler: {0}", e.ToString()) + "\n";
      }
   }
}
/*
This code example produces the following results:

ArithmeticException Handler: System.DivideByZeroException: Attempted to divide by zero.
   at ExceptionTestClass.Main()

*/


Windows Phone OS

受以下版本支持: 8.0, 7.1, 7.0

Windows Phone

此类型的所有公共 static(在 Visual Basic 中为 Shared) 成员都是线程安全的。但不保证所有实例成员都是线程安全的。

显示: