手机
当前位置:查字典教程网 >编程开发 >C#教程 >解析c#在未出现异常情况下查看当前调用堆栈的解决方法
解析c#在未出现异常情况下查看当前调用堆栈的解决方法
摘要: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("logHasImageErrorCheckerPostExtension").Write(sb.ToString());

}

}

catch (Exception ex)

{

TextLogWriter.NamedInstance("logHasImageErrorCheckerPostExtension").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#在未出现异常情况下查看当前调用堆栈的解决方法】相关文章:

C#中Web.Config加密与解密的方法

C#调用Java类的实现方法

c#中判断字符串是不是数字或字母的方法

C#几种截取字符串的方法小结

解析使用enumerator模式简化异步操作的详解

解析C#中委托的同步调用与异步调用(实例详解)

深入C# winform清除由GDI绘制出来的所有线条或图形的解决方法

解析StreamReader与文件乱码问题的解决方法

使用异步方式调用同步方法(实例详解)

使用C#实现在屏幕上画图效果的代码实例

精品推荐
分类导航