zoukankan      html  css  js  c++  java
  • 浅谈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可以写一个错误日志提示的接口!

  • 相关阅读:
    CentOS7中使用yum安装Nginx的方法
    vsftp上传文件权限
    java传入ftp 0k
    centos 7.0 查看selinux状态|关闭|开启
    NamingException
    fastdfs服务器搭建
    安装gnome图形界面程序
    MAVEN插件-tomcat插件,java编译插件,资源文件拷贝插件
    spring ioc
    jsp全路径
  • 原文地址:https://www.cnblogs.com/mistor/p/2063192.html
Copyright © 2011-2022 走看看