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。

原文地址:https://www.cnblogs.com/peterYong/p/13582138.html