• 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。

  • 相关阅读:
    PHP中使用CURL实现GET和POST请求
    ecstore关于smarty语法调用
    Linux 定时任务详解
    fzu 1753 Another Easy Problem
    zoj 2562 More Divisors
    poj 2992 Divisors
    UVA10078多边形判断凹凸性
    UVA10002求凸包的质心
    UVA10088多边形内整点个数计算(计算几何)
    HDU 1824 简单2-sat
  • 原文地址:https://www.cnblogs.com/peterYong/p/13582138.html
Copyright © 2020-2023  润新知