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--------嘗試除以零。

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM