浅谈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可以写一个错误日志提示的接口!

posted @ 2011-05-30 12:59  黎明&岁月  阅读(7787)  评论(0编辑  收藏  举报