对于异常,我们经常用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--------尝试除以零。
--------------------------------------------
本文系原创,转载请注明出处。
如果文章对您有帮助,可以点击下方的【好文要顶】或【关注我】;如果您想进一步表示感谢,可通过网页右侧的【打赏】功能进行打赏。
感谢您的支持,我会继续写出更多的相关文章!文章有不理解的地方欢迎跟帖交流,博主经常在线!^_^