浅谈C# StackTrace 类的实例说明
基本知识讲解详见 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可以写一个错误日志提示的接口!
业精于勤荒于嬉 行成于思毁于随

浙公网安备 33010602011771号