当前位置:  编程技术>.net/c#/asp.net

解析c#在未出现异常情况下查看当前调用堆栈的解决方法

    来源: 互联网  发布时间:2014-10-20

    本文导语:  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}rn", stack.GetFileName(),
                stack.GetFileLineNumber(),
                stack.GetFileColumnNumber(),
                stack.GetMethod().ToString());
        }
        return result;
    }
}

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

    
 
 

您可能感兴趣的文章:

  • C#解析JSON实例
  • 解析C#中#region与#if的作用
  • C# DES加密算法中向量的作用详细解析
  • C#中FormClosing与FormClosed的区别详细解析
  • c#中switch case的用法实例解析
  • C#枚举类型与结构类型实例解析
  • js substr,substring与java substring和C# substring的区别解析
  • C#类的创建与初始化实例解析
  • c#使用htmlagilitypack解析html格式字符串
  • C#的WebBrowser操作frame实例解析
  • 解析C#中如何把控件的边框角画为圆弧
  • 解析c#显示友好时间的实现代码
  • C#中out与ref的区别实例解析
  • C#事务处理(Execute Transaction)实例解析
  • c#使用nsoup解析html乱码解决方法分享 nsoup教程
  • 解析C#彩色图像灰度化算法的实现代码详解
  • Visual C#类的定义及实现方法实例解析
  • C#中私有构造函数的特点和用途实例解析
  • 解析c#操作excel后关闭excel.exe的方法
  • C#委托所蕴含的函数指针概念详细解析
  •  
    本站(WWW.)旨在分享和传播互联网科技相关的资讯和技术,将尽最大努力为读者提供更好的信息聚合和浏览方式。
    本站(WWW.)站内文章除注明原创外,均为转载、整理或搜集自网络。欢迎任何形式的转载,转载请注明出处。












  • 相关文章推荐
  • shell自定义函数及参数调用解析
  • 解析c语言中"函数调用中缺少哨兵"的情况分析
  • 解析C#中委托的同步调用与异步调用(实例详解)
  • 解析如何使用反射调用类型成员 方法,字段,属性
  • c#方法中调用参数的值传递方式和引用传递方式以及ref与out的区别深入解析
  • 解析如何在C语言中调用shell命令的实现方法
  • Jquery Ajax解析XML数据(同步及异步调用)简单实例
  • 解析在main函数之前调用函数以及对设计的作用详解
  • 解析Silverlight调用WCF/Rest异常的解决方法
  • C++调用迅雷接口解析XML下载功能(迅雷下载功能)
  • jquery.Ajax()方法调用Asp.Net后台的方法解析
  • windows下tinyxml.dll下载安装使用(c++解析XML库)
  • 请教redhat9下什么命令执行arp解析和逆向arp解析
  • 使用libpcap读取tcpdump抓取的文件并解析c代码实例
  • 如何用libxml2 默认解析器解析HTML文件
  • 基于Python的Html/xml解析库Beautiful Soup 4.2.1发布
  • linux能否成为动态域名解析客户端的动态域名解析服务器?
  • html中<radio>单选按钮控件标签用法解析及如何设置默认选中
  • 配置DNS服务器后,服务器可解析,客户端不能解析。求解
  • Python下Html/xml解析库Beautiful Soup快速入门教程
  • 为什么我在使用nslookup命令的时候,正向解析(域名-》ip)没有问题,反向解析(ip-》域名)怎么查不到呢?
  • 基于Python的html解析库:pyquery最新版主页及pyquery下载
  • 服务器本机能解析域名,其它机子都解析不到,能ping通dns服务器地址,是什么问题?//
  • python下xml解析库lxml最新版下载安装以及代码示例
  • 我有一个DNS服务器,既要解析自己局域网里IP,有要解析外网上的IP,如www.163.com,我该如何设置呢
  • python对XML的解析方法(SAX,DOM,ElementTree)介绍
  • 请问怎样手工的解析XML文件啊.( 不借助任何的xml解析器)急!!!
  • php通过pack和unpack函数实现对二进制数据封装及解析
  • 通过shell解析文件,并根据解析内容生成新的文件。
  • html中<checkbox>标签用法解析及如何设置checkbox复选框的默认选中状态
  • java 公式解析 表达式解析 expression-analyzer


  • 站内导航:


    特别声明:169IT网站部分信息来自互联网,如果侵犯您的权利,请及时告知,本站将立即删除!

    ©2012-2021,,E-mail:www_#163.com(请将#改为@)

    浙ICP备11055608号-3