环境:
- window11
- vs2022
- .netcore3.1
异常的堆栈信息是蛮重要的,它能帮助我们快速定位出错的代码位置!
如下图所示:
我们观察异常的堆栈信息,发现它有如下特点:
- 打印的堆栈信息是由内而外,所以我们先看到的是“最初”抛出异常的代码;
- 打印的每一行都是一个方法的调用点,同时,一个方法内只能有一行显示在堆栈信息上(不考虑循环调用和箭头函数);
注意:函数的调用是一种堆栈结构。
其实,除了抛异常,我们使用 Environment.StackTrace
也可以打印堆栈信息,如下图:
重点: throw 和 throw ex 的区别?
有这样的场景:我们封装一个事务方法,当捕获到异常时,需要将事务回滚,同时我们还需要将异常抛出。看如下代码:
先说下结论:
- 当使用
throw ex
的时候,我们无法根据异常堆栈精确定位到出错的代码行数(第16行),因为throw ex
本身也是一行代码,它和throw new Exception("123")
没有什么不同,所以,c#会重新计算堆栈信息赋值给ex
,就像throw new Exception("sql语句异常");
这行代码一样。 - 当使用
throw
的时候,c#不会重新计算堆栈信息,而是直接将捕获到的异常抛出去;
它们运行的效果如下:
另外,如果我们不喜欢使用 throw
,也可以使用 throw new Exception("",ex);
来代替,不过,打印异常时,我们就要打印 ex.InnerException了。