zoukankan      html  css  js  c++  java
  • 黑马程序员异常捕获和处理

                  

     1 class Program
     2     {
     3         static void Main(string[] args)
     4         {
     5             Test();
     6         }
     7         public static void Test()
     8         {
     9             try
    10             {
    11                 int num = 0;
    12                 num = 10 / num;
    13             }
    14             catch (Exception)
    15             {
    16 
    17                 throw;
    18             }
    19         }
    20     }

    异常

    未处理System.DivideByZeroException
      HResult=-2147352558
      Message=尝试除以零。
      Source=ConsoleApplication1
      StackTrace:
           在 ConsoleApplication1.Program.Test() 位置 k:\Desktop\TestTemp\ConsoleApplication1\Program.cs:行号 26
           在 ConsoleApplication1.Program.Main(String[] args) 位置 k:\Desktop\TestTemp\ConsoleApplication1\Program.cs:行号 12
           在 System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
           在 Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
           在 System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
           在 System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
           在 System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
           在 System.Threading.ThreadHelper.ThreadStart()
      InnerException:


    这里显示得到 在12行的时候出错。尝试除以零。

     1   static void Main(string[] args)
     2         {
     3             Test();
     4             Console.ReadKey();
     5         }
     6         public static void Test()
     7         {
     8             try
     9             {
    10                 int num = 0;
    11                 num = 10 / num;
    12             }
    13             catch (Exception ex)
    14             {
    15                 //打印出异常信息
    16                 Console.WriteLine(  ex.ToString());
    17             }
    18         }


     显示异常的信息

    System.DivideByZeroException: 尝试除以零。
       在 ConsoleApplication1.Program.Test() 位置 k:\Desktop\TestTemp\ConsoleApplica
    tion1\Program.cs:行号 20

    可以看到显示的是20行错误  异常信息是尝试除以零

    在这里为什么不提示 11行错误呢?因为这里使用了try-catch 来捕获异常后又抛出了异常信息。 所以就错误中就只留下了throw的错误信息。

    如果想要知道具体的异常就需要自定义异常。解决如下。

     1         static void Main(string[] args)
     2         {
     3             Test();
     4             Console.ReadKey();
     5         }
     6         public static void Test()
     7         {
     8             try
     9             {
    10                 int num = 0;
    11                 num = 10 / num;
    12             }
    13             catch (Exception ex)
    14             {
    15                 //打印出异常信息
    16                 throw new Exception("这里异常了", ex);
    17             }
    18         }

    抛出异常信息:

    未处理System.Exception
      HResult=-2146233088
      Message=这里异常了
      Source=ConsoleApplication1
      StackTrace:
           在 ConsoleApplication1.Program.Test() 位置 k:\Desktop\TestTemp\ConsoleApplication1\Program.cs:行号 27
           在 ConsoleApplication1.Program.Main(String[] args) 位置 k:\Desktop\TestTemp\ConsoleApplication1\Program.cs:行号 12
           在 System.AppDomain._nExecuteAssembly(RuntimeAssembly assembly, String[] args)
           在 Microsoft.VisualStudio.HostingProcess.HostProc.RunUsersAssembly()
           在 System.Threading.ExecutionContext.RunInternal(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
           在 System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state, Boolean preserveSyncCtx)
           在 System.Threading.ExecutionContext.Run(ExecutionContext executionContext, ContextCallback callback, Object state)
           在 System.Threading.ThreadHelper.ThreadStart()
      InnerException: System.DivideByZeroException
           HResult=-2147352558
           Message=尝试除以零。
           Source=ConsoleApplication1
           StackTrace:
                在 ConsoleApplication1.Program.Test() 位置 k:\Desktop\TestTemp\ConsoleApplication1\Program.cs:行号 20
           InnerException:

    因为这里重新定义了  throw new Exception("这里异常了", ex);  异常。所以就抛出了自己定义的异常信息。message

      

    最近发现如果不需要处理异常 。不用 throw ex。

    如下:

     1    static void Main(string[] args)
     2         {
     3             Test();
     4             Console.ReadKey();
     5         }
     6         public static void Test()
     7         {
     8             try
     9             {
    10                 int num = 0;
    11                 num = 10 / num;
    12             }
    13             catch (Exception ex)
    14             {
    15                 //打印出异常信息
    16                 throw ;
    17             }
    18         }

    直接throw即可。

    如果不需要异常信息。写法:

     1       static void Main(string[] args)
     2         {
     3             Test();
     4             Console.ReadKey();
     5         }
     6         public static void Test()
     7         {
     8             try
     9             {
    10                 int num = 0;
    11                 num = 10 / num;
    12             }
    13             finally
    14             {
    15                 //把占用资源释放掉
    16             }
    17         }

                  

    __EOF__

    本文作者 Blank
    本文链接
    版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
    声援博主:如果您觉得文章对您有帮助,可以点击文章右下角 推荐 一下。您的鼓励是博主的最大动力!
  • 相关阅读:
    【转】团队管理
    Oracle 11g中关于数据定义的思考
    【转】InfoQ的Java安全认证机制
    Oracle 11g windows简体中文版安装指南
    【转】InfoQ的集成Java内容仓库和Spring
    Oracle数据库常用操作命令(一)
    常用DQL
    如何处理Oracle客户端查询乱码问题
    Documentum中的TCS与对应权限设置
    【转】Windows系统下的Apache性能优化mpm
  • 原文地址:https://www.cnblogs.com/alianblank/p/3023851.html
Copyright © 2011-2022 走看看