zoukankan      html  css  js  c++  java
  • C# 获取当前方法/父方法的信息

    System.Diagnostics.StackTrace

    1.(new StackTrace()).GetFrame(1) // 0为本身的方法;1为调用方法
    2.(new StackTrace()).GetFrame(1).GetMethod().Name; // 方法名
    3.(new StackTrace()).GetFrame(1).GetMethod().ReflectedType.Name; // 类名

    获取当前方法的名称空间、类名和方法名称

    public string GetMethodInfo()
    {
        string str = "";
    
        //取得当前方法命名空间    
        str += "命名空间名:" + System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Namespace + "
    ";
    
        //取得当前方法类全名 包括命名空间    
        str += "类名:" + System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.FullName + "
    ";
    
        //取得当前方法名    
        str += "方法名:" + System.Reflection.MethodBase.GetCurrentMethod().Name + "
    "; str += "
    ";
    
        //父方法
        System.Diagnostics.StackTrace ss = new System.Diagnostics.StackTrace(true);
        System.Reflection.MethodBase mb = ss.GetFrame(1).GetMethod();
    
        //取得父方法命名空间    
        str += mb.DeclaringType.Namespace + "
    ";
    
        //取得父方法类名    
        str += mb.DeclaringType.Name + "
    ";
    
        //取得父方法类全名    
        str += mb.DeclaringType.FullName + "
    ";
    
        //取得父方法名    
        str += mb.Name + "
    "; return str;
    }
    View Code

    使用

    添加错误日志时 使用:

      public static bool AddErrorLog(string content)
            {
                //父方法
                System.Diagnostics.StackTrace ss = new System.Diagnostics.StackTrace(false);
                string invokeMethodName = ss.GetFrame(1)?.GetMethod()?.Name;
                return logDAL.AddErrorLog($"{invokeMethodName} throw a exception:{content}");
            }

    invokeMethodName 有时获取到的是:MoveNext

    调试发现,捕获异常直接调写日志AddErrorLog,则能正确获取到 父方法的名称;而捕获到异常 然后直接throw抛出,在外层方法中 调写日志AddErrorLog的话,则取的父方法名称是MoveNext。

  • 相关阅读:
    053-649
    053-648
    053-647
    053-646
    053-645
    053-644
    053-643
    053-642
    053-641
    053-640
  • 原文地址:https://www.cnblogs.com/peterYong/p/13582138.html
Copyright © 2011-2022 走看看