让你的代码输出exception发生时所在的文件名, 行号, 列号

代码如下:

try
{
    //Your Code Here
}
catch (Exception ex)
{
    Console.WriteLine(ex.Message);

    System.Diagnostics.StackTrace trace = 
        new System.Diagnostics.StackTrace(ex, true);
    Console.WriteLine(
        trace.GetFrame(trace.FrameCount - 1).GetMethod().Name);
    Console.WriteLine(
        trace.GetFrame(trace.FrameCount - 1).GetFileLineNumber());
    Console.WriteLine(
        trace.GetFrame(trace.FrameCount - 1).GetFileColumnNumber());
}

 

简单一点的, 可以使用Exception.ToString().

ex.ToString()的样例输出:

System.InvalidCastException: Unable to cast object of type 'Microsoft.SharePoint.SPList' to type 'Microsoft.SharePoint.SPDocumentLibrary'.
   at GetFolderLength.Program.Main(String[] args) in E:\code\csharp\project1\Program.cs:line 110

 

System.AppDomain.CurrentDomain.BaseDirectory.ToString()的结果如下:

E:\code\csharp\project1\bin\Debug\

 

参考资料:

Getting line numbers in exception stack trace in a Windows Service

http://dnchannel.blogspot.com/2007/09/getting-line-numbers-in-exception-stack.html

System.Diagnostics.StackTrace or System.Diagnostics.StackFrame for debugging ? Why

http://stackoverflow.com/questions/925737/system-diagnostics-stacktrace-or-system-diagnostics-stackframe-for-debugging-w

Caveats about System.Diagnostics.StackTrace

http://blogs.msdn.com/jmstall/archive/2005/03/20/399287.aspx

posted on   中道学友  阅读(1297)  评论(0编辑  收藏  举报

编辑推荐:
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 单元测试从入门到精通
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律

导航

< 2010年4月 >
28 29 30 31 1 2 3
4 5 6 7 8 9 10
11 12 13 14 15 16 17
18 19 20 21 22 23 24
25 26 27 28 29 30 1
2 3 4 5 6 7 8

技术追求准确,态度积极向上

点击右上角即可分享
微信分享提示