c#在未出现异常情况下查看当前调用堆栈

17 篇文章 0 订阅

http://www.cnblogs.com/yukaizhao/archive/2012/05/08/csharp-stacktrace.html

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模式下可以得到具体的文件行号,列号。

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


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值