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

Posted xh6300

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了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:\\Users\\happy xia\\Documents\\Visual Studio 2013\\Projects\\Windows_控制台输出\\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--------尝试除以零。

 

以上是关于C#在控制台输出异常所在的行数的主要内容,如果未能解决你的问题,请参考以下文章

方法之根据键盘录入的行数和列数,在控制台输出星形

php 打印当前执行到的行数--为方便调试

linux的文本处理

c#调用存储过程查询表并返回影响的行数

使用实体框架迁移时 SQL Server 连接抛出异常 - 添加代码片段

如何将控制台窗口的大小调整为设定的行数和列数?