博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
c#在未出现异常情况下查看当前调用堆栈
阅读量:5752 次
发布时间:2019-06-18

本文共 2269 字,大约阅读时间需要 7 分钟。

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://vtkkx.baihongyu.com/

你可能感兴趣的文章
【VMCloud云平台】SCAP(四)租户(一)
查看>>
linux释放内存的方法
查看>>
基于 Android NDK 的学习之旅----- C调用Java
查看>>
Google 或强制 OEM 预装 20 款应用,给你一个不Root的理由
查看>>
我的友情链接
查看>>
双边过滤器(Bilateral filter)
查看>>
Android图形显示系统——下层显示4:图层合成上(合成原理与3D合成)
查看>>
Windows 10 技术预览
查看>>
Tomcat http跳转https
查看>>
一个自动布署.net网站的bat批处理实例
查看>>
tomcat 安装
查看>>
AIX:物理卷及有关概念
查看>>
我的友情链接
查看>>
Centos6.6安装选包及基础场景说明
查看>>
《从零开始学Swift》学习笔记(Day 61)——Core Foundation框架之内存管理
查看>>
java基础面试题-1
查看>>
深克隆与序列化效率的比较
查看>>
lamp+nginx代理+discuz+wordpress+phpmyadmin搭建一
查看>>
nagios监控使用139邮箱报警
查看>>
Windows Phone 7 中各种Task解说(启动器与选择器)
查看>>