• C#查看堆栈通常是在异常


    C#查看堆栈通常是在异常处理中,出现异常之后通过异常的堆栈可以很方便的得到出现这个错误的代码调用路径。这个很有用,是否可以在没有异常出现时使用这种方法排查一些非异常错误呢?答案是肯定的。

    起因:

    论坛发帖子有几个途径,有可能是新闻系统直接导入的帖子,也有可能是抓取的帖子,还有可能是用户通过正常途径发表。但是这两天出了一个问题,有些帖子的HasImage属性不对。通过几种方法做调试都不能重现问题,没有办法,只有在程序中添加回复的地方添加日志程序来记录堆栈,从而追踪到是哪个途径发帖出现了问题。

    代码:

    [PostProviderExtension]
    public class HasImageErrorCheckerPostExtension : IPostProviderExtension
    {
        public void BindEvents(PostProviderBase postProvider)
        {
            postProvider.Added += new PostChanged(postProvider_Added);
        }
     
        void postProvider_Added(Model.PostInfo post)
        {
            try
            {
                StackFrame[] stacks = new StackTrace().GetFrames();
                if (post.Content.IndexOf("IMG") > -1 && post.HasImage == false)
                {
                    StringBuilder sb = new StringBuilder();
                    sb.AppendLine("问题出现");
                    sb.AppendLine("stack is:");
                    sb.Append(ToString(stacks));
     
                    sb.Append("content=");
                    sb.AppendLine(post.Content);
                         
                    sb.Append("HasImage=");
                    sb.AppendLine(UserPostContentProcessor.HasImage(post.Content).ToString());
     
                    sb.Append("createUserID=");
                    sb.AppendLine(post.CreateUserID.ToString());
                    sb.AppendLine(string.Format("LoginUser={0},Level={1}",PageBase.GetLoginUser().ID,PageBase.GetLoginUser().LevelNo));
     
                    TextLogWriter.NamedInstance("\\log\\HasImageErrorCheckerPostExtension\\").Write(sb.ToString());
                }
            }
            catch (Exception ex)
            {
                TextLogWriter.NamedInstance("\\log\\HasImageErrorCheckerPostExtension\\").Write(ex);
            }
        }
     
        private string ToString(StackFrame[] stacks)
        {
            string result = string.Empty;
            foreach (StackFrame stack in stacks)
            {
                result += string.Format("{0} {1} {2} {3}\r\n", stack.GetFileName(),
                    stack.GetFileLineNumber(),
                    stack.GetFileColumnNumber(),
                    stack.GetMethod().ToString());
            }
            return result;
        }
    }

    上面类HasImageErrorCheckerPostExtension继承自IPostProviderExtension并且有PostProviderExtension属性修饰,系统会自动调用它并在发帖时触发这里绑定的事件。这里的核心代码是new StackTrace().GetFrames()通过这个方法可以得到当前程序执行时的堆栈信息。在Release模式下可以得到调用的方法名,在Debug模式下可以得到具体的文件行号,列号。

    这个方法是调试中不能重现问题时的一种查找问题的选择方案。

    我的微博地址是:http://weibo.com/yukaizhao 我会把一些技术心得碎片写到微博中,欢迎关注。
    分类: .Net开发经验c#
  • 相关阅读:
    浅谈REST[转]
    linuxyum
    XAMPPAccess denied for user 'root'@'localhost' (using password:YES)....& can't connect to localhost...
    ps aux详细解释【转】
    TOP 10:值得关注的十家云计算公司【转】
    isnull在数据库查询中的应用
    正则匹配代码
    推荐一款生成SQL插入语句的软件
    网页自动刷新
    执行SQL脚本语句判断是否已经存在
  • 原文地址:https://www.cnblogs.com/Leo_wl/p/2490118.html
Copyright © 2020-2023  润新知