在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
System.Diagnostics.StackTrace1.(new StackTrace()).GetFrame(1) // 0为本身的方法;1为调用方法 获取当前方法的名称空间、类名和方法名称 public string GetMethodInfo() { string str = ""; //取得当前方法命名空间 str += "命名空间名:" + System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.Namespace + "\n"; //取得当前方法类全名 包括命名空间 str += "类名:" + System.Reflection.MethodBase.GetCurrentMethod().DeclaringType.FullName + "\n"; //取得当前方法名 str += "方法名:" + System.Reflection.MethodBase.GetCurrentMethod().Name + "\n"; str += "\n"; //父方法 System.Diagnostics.StackTrace ss = new System.Diagnostics.StackTrace(true); System.Reflection.MethodBase mb = ss.GetFrame(1).GetMethod(); //取得父方法命名空间 str += mb.DeclaringType.Namespace + "\n"; //取得父方法类名 str += mb.DeclaringType.Name + "\n"; //取得父方法类全名 str += mb.DeclaringType.FullName + "\n"; //取得父方法名 str += mb.Name + "\n"; 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。
|
请发表评论