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; }
使用
添加错误日志时 使用:
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。