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选择的语言是英文,那么这里的“行数”一词是对应的英文)

如果考虑不同语言环境的兼容性,以字符串“行号”为标记截取字符串的话,并不是最好的方式。

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

 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--------尝试除以零。

时间: 2024-10-14 01:47:15

C#在控制台输出异常所在的行数的相关文章

在控制台输出所有的“水仙华数”

/*分析: * 所谓的水仙花是指一个三位数,其各位数字的立方和等于该数本身 * 举例:153就是一个水仙花数. * 153 = 1*1*1 + 5*5*5 + 3*3*3 = 1 + 125 +27 =153 * * A:三位数其实是告诉了我们范围 * B:通过for循环我们就可以实现获取每一个三位数 * 但是麻烦是如何获取这个三位数的个,十,百位上的数据 * * 我们如何获取一个数据的个,十,百呢? * 假设有个一个数据:153 * ge: 153%10 = 3 * shi: 153/10%1

nodejs 像 C 语言那样输出当前代码的行数

http://stackoverflow.com/questions/11386492/accessing-line-number-in-v8-javascript-chrome-node-js 1 Object.defineProperty(global, '__stack', { 2 get: function(){ 3 var orig = Error.prepareStackTrace; 4 Error.prepareStackTrace = function(_, stack){ re

更改Windows控制台默认缓冲区行数和宽度

Windows控制台窗口默认的显示行数很少, 以至于有时候要显示很多东西的时候, 总是导致前面的内容丢失. 很不爽. 于是GG了下, 在StackOverflow上找到了答案~~~ 设置方式: 1. 打开注册表                       2.定位到 HKCU\Console\%SystemRoot%_System32_cmd.exe                       3.添加(如果没有)一个新的32位DWORD值, 并按如下要求填写其值:               

查找目录下的关键字以及显示行数

1 import os 2 def print_pos(key_dict): 3 keys = key_dict.keys() 4 keys = sorted(keys) # 由于字典是无序的,我们这里对行数进行排序 5 for each_key in keys: 6 print('关键字出现在第 %s 行,第 %s 个位置.' % (each_key, str(key_dict[each_key]))) 7 8 def pos_in_line(line, key): 9 pos = [] 10

Linux:从文件中搜索关键字并显示行数(cat,grep函数)

假如有test1.txt的格式如下图所示: 有test2.txt的内容如下: 现需将test2.txt含有的关键字的行搜索出来并显示行数 则可以用到命令: cat test1.txt | grep -nf test2.txt 运行后,效果如下: 36840733和36909134表示含有这两个关键字所在的行数.

【Java】控制异常在控制台输出

每次在Java程出现问题,总会抛出一大堆异常,让人眼花缭乱,在Javaweb编程的时候尤甚,让人很难找到出错的位置, 尤其在你网络工程文件多.插件多.框架的时候,各种插件.框架连锁,导致你更难找到出错的位置. 其实异常在控制台输出是可以控制的. 关键是利用到,这个方法与数组.对象都是java自带的,不用引入任何东西: StackTraceElement[] stacks = new Throwable().getStackTrace(); 这个操作. 先看一段程序, public static

【Java】Eclipse新建的Java文件自动生成主函数、控制台输出行数不再受限制

一.新建的Java文件自动生成主函数 虽然只是一个很简单的事情,但应该还是有人不知道了,每次新建Java文件都要手动输入public static void main(String args[]){},非常麻烦,其实Eclipse可以自动生成这行,只是大多数的Java文件都是没有主函数的,所以这行默认关闭, 右击Java项目下的src可以选择New->Class也就可以新建类 然后在弹出的对话框上勾上自动产生主函数,点击确认,在生产的Java文件中就有主函数了 二.Eclipse控制台输出行数不

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

根据键盘录入的行数和列数,在控制台输出星形: import java.util.Scanner; class Hello2 { public static void main(String[] args) { Scanner sc = new Scanner(System.in); System.out.println("请输入一个行数"); int x = sc.nextInt(); System.out.println("请输入一个列数"); int y = s

控制台输出是什么回事

1.控制台输出,是指程序运行过程中,将一些信息,output出来,用输出流,可以输出到指定文件或者控制台. 2.日志信息,就是程序中的标准input/output stream,只是将i/o的目的地输出到console这个程序而已. 3.console是个单独的系统程序,console是单独的程序,否则怎么动态输出log信息?是的,console底层就是c语言的printf . 4.大部分ide开发环境也都提供了自己console程序,比如eclipse和tomcat.要打印程序的log信息,只