• C#在控制台输出异常所在的行数


    对于异常,我们经常用try-catch语句来处理,一种常见的方式是在catch语句块用MessageBox.Show("异常")这种弹窗的方式来报告异常。但是有些时候,有些异常发生时我们不希望弹窗干扰用户,只是想要打印出异常信息查找原因、分析调试而已。

    这时候常用的方法有:打印log将异常信息保存到文本中、将异常信息输出到可显示文本的控件中、将异常打印到“输出”窗口中。

    其中涉及的关键问题是:如何快速定位异常所在的位置。如果可以输出异常所在的行数其实就可以很好解决这一问题了。 

    设计一个异常如下:点击button1,执行一个“除以0”的异常:

     1 using System;
     2 using System.Collections.Generic;
     3 using System.ComponentModel;
     4 using System.Data;
     5 using System.Drawing;
     6 using System.Linq;
     7 using System.Text;
     8 using System.Windows.Forms;
     9 
    10 namespace Windows_控制台输出
    11 {
    12     public partial class Form1 : Form
    13     {
    14         public Form1()
    15         {
    16             InitializeComponent();
    17         }
    18 
    19         private void button1_Click(object sender, EventArgs e)
    20         {
    21             int i = 0;
    22 
    23             try
    24             {
    25                 int j = 10/i;
    26             }
    27             catch (Exception ex)
    28             {
    29                 string str = ex.StackTrace;
    30                 Console.WriteLine(str);
    31             }
    32            
    33         }
    34     }
    35 }

    控制台输出窗口打印:

       在 Windows_控制台输出.Form1.button1_Click(Object sender, EventArgs e) 位置 c:Usershappy xiaDocumentsVisual Studio 2013ProjectsWindows_控制台输出Windows_控制台输出Form1.cs:行号 25

    它表明异常出现在Form1.button1_Click方法中,出现在文件Form1.cs中,并给出了该文件的全路径,最后显示出现的行数为25。

    其实我们最想得到的信息是:Form1.cs:行号 25。(注意:如果Visual Studio选择的语言是英文,那么这里的“行号”一词是对应的英文)

    如果考虑不同语言环境的兼容性,以字符串“行号”为标记截取字符串的话,并不是最好的方式。此时可以考虑以“cs:”为标记,但是这不易准确得到发生异常的文件名(这里是Form1.cs)。

    我们可以考虑以最后一个反斜杠“”作为截取的标记。此时程序为:

     1 private void button1_Click(object sender, EventArgs e)
     2         {
     3             int i = 0;
     4 
     5             try
     6             {
     7                 int j = 10/i;
     8             }
     9             catch (Exception ex)
    10             {
    11                 string str = ex.StackTrace;
    12                 Console.WriteLine(str.Substring(str.LastIndexOf("\") + 1, str.Length - str.LastIndexOf("\") - 1) ); 
    13             }
    14            
    15         }

    控制台输出窗口打印:

    Form1.cs:行号 25

    如果要顺带输出异常的内容的话,代码如下:

     1 private void button1_Click(object sender, EventArgs e)
     2         {
     3             int i = 0;
     4 
     5             try
     6             {
     7                 int j = 10/i;
     8             }
     9             catch (Exception ex)
    10             {
    11                 string str = ex.StackTrace;
    12                 Console.WriteLine("异常:  " + str.Substring(str.LastIndexOf("\") + 1, str.Length - str.LastIndexOf("\") - 1) + "--------" + ex.Message);  
    13             }
    14            
    15         }

    控制台输出窗口打印:

    异常:  Form1.cs:行号 25--------尝试除以零。

  • 相关阅读:
    git修改文件名大小写的方法。
    VC中常用的宏
    spring cloud Zuul 多层拦截 --- 心得
    Zuul网关 @EnableZuulProxy 和 @EnableZuulServer 的区别
    jave 数据类型 float 的 正确赋值
    spring cloud bus 消息总线 动态刷新配置文件 【actuator 与 RabbitMQ配合完成】
    RabbitMQ 消息中间件 的下载与安装【window10】
    spring cloud --- 使用 actuator 热更新【刷新】单机配置文件
    spring cloud 与spring boot的版本对应总结
    spring cloud feign 报错 feign.FeignException$MethodNotAllowed: status 405 reading 解决
  • 原文地址:https://www.cnblogs.com/xh6300/p/6338398.html
Copyright © 2020-2023  润新知