解析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#调用dll,dll加载epk
易语言c#调用dll,dll加载epk例子源代码,通过c#调用dll,易语言写dll调用epk。...
- C#版的模块中所有的api和相关的结构体的声明
C#版的模块中所有的api和相关的结构体的声明例子源代码,直接用易语言封装成dll调用。...
- c#版写的重命名工具
c#版写的重命名工具绿色版,之前记得有个跟这个界面类似的重命名,后来一直找不到了,下载转存太麻烦了就自己弄...
- C#开源利用OpenCV找图经典例子
C#开源利用OpenCV找图经典例子绿色版,没有使用最新本版是因为该本版.NET4.0就能跑。...
- 利用RtlWalkFrameChain回溯调用堆栈
易语言利用RtlWalkFrameChain回溯调用堆栈例子源代码,某游戏调用写的扣出来分享。...
- 把其它应用嵌入到C#窗口源代码
把其它应用嵌入到C#窗口源代码本文件感兴趣的可以参考一下,把一个现有的窗体应用程序界面嵌入到自己开发的...
- C#H264格式视频解码
C#H264格式视频解码本文件感兴趣的可以参考一下,使用FFMPEG解码为H264视频文件。...
- C# WinCE播放器WinCE_PlayMusic
C#WinCE播放器本文件感兴趣的可以参考一下,可播放*.wav,*.mp3等语音文件。...
- C#自动远程时间同步助手
C#自动远程时间同步助手本文件感兴趣的可以参考一下,时间服务器的ntp服务开启状态。...
- C#文件加密解密完整项目
C#文件加密解密完整项目本文件感兴趣的可以参考一下,实现C#加密各种文件和解密加密后的文件。...
- C#基于UDP的呼叫应答系统
C#基于UDP的呼叫应答系统本文件感兴趣的可以参考一下,一个简单的基于UDP的呼叫应答及时提醒系统。...
- C#商品销售管理系统
C#商品销售管理系统本文件感兴趣的可以参考一下,数据库课程设计做的,用到了SQLServer数据库。...