基本知识讲解详见 http://msdn.microsoft.com/zh-cn/library/system.diagnostics.stacktrace.aspx
基础实例见:http://www.cnblogs.com/isabelincoln/archive/2006/11/02/547544.html 这个文章 要加2个引用 才能运行成功
using System.Diagnostics;
using System.Reflection; //反射
其中调用GetFrame得到栈空间,参数index 表示栈空间的级别,0表示当前栈空间,1表示上一级的栈空间,依次类推。
除了可以获取方法信息外,还可以调用StackFrame类的成员函数,在运行时得到代码的文件信息及行号和列号等
如下实例:
using System; using System.Collections.Generic; using System.Linq; using System.Text; using System.Diagnostics; using System.Reflection; namespace ConsoleTest { class Program { static void Main(string[] args) { MyInternalClass myClass = new MyInternalClass(); myClass.MyPublicMethod(); } } class MyInternalClass { public void ThrowsException() { try { throw new Exception("错误信息"); } catch { StackTrace st = new StackTrace(true); string stackIndent = ""; for (int i = 0; i < st.FrameCount; i++) { StackFrame sf = st.GetFrame(i); Console.WriteLine(); //得到错误的方法 Console.WriteLine(stackIndent + " Method: {0}", sf.GetMethod()); //得到错误的文件名 Console.WriteLine(stackIndent + " File: {0}", sf.GetFileName()); //得到文件错误的行号 Console.WriteLine(stackIndent + " Line Number: {0}", sf.GetFileLineNumber()); //得到错误的列 Console.WriteLine(" Column Number: {0}", sf.GetFileColumnNumber()); stackIndent += " "; } } } protected void MyProtectedMethod() { MyInternalClass mic = new MyInternalClass(); mic.ThrowsException(); } public void MyPublicMethod() { MyProtectedMethod(); } } }
结果如图:
我们可以结合LOG4NET可以写一个错误日志提示的接口!