• 设为首页
  • 点击收藏
  • 手机版
    手机扫一扫访问
    迪恩网络手机版
  • 关注官方公众号
    微信扫一扫关注
    公众号

C#获取当前方法/父方法的信息

原作者: [db:作者] 来自: [db:来源] 收藏 邀请

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 + "\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;
}
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。

 


鲜花

握手

雷人

路过

鸡蛋
该文章已有0人参与评论

请发表评论

全部评论

专题导读
热门推荐
热门话题
阅读排行榜

扫描微信二维码

查看手机版网站

随时了解更新最新资讯

139-2527-9053

在线客服(服务时间 9:00~18:00)

在线QQ客服
地址:深圳市南山区西丽大学城创智工业园
电邮:jeky_zhao#qq.com
移动电话:139-2527-9053

Powered by 互联科技 X3.4© 2001-2213 极客世界.|Sitemap