-
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("\\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模式下可以得到具体的文件行号,列号。
这个方法是调试中不能重现问题时的一种查找问题的选择方案。
起因:
论坛发帖子有几个途径,有可能是新闻系统直接导入的帖子,也有可能是抓取的帖子,还有可能是用户通过正常途径发表。但是这两天出了一个问题,有些帖子的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模式下可以得到具体的文件行号,列号。
这个方法是调试中不能重现问题时的一种查找问题的选择方案。
栏目列表
最新更新
nodejs爬虫
Python正则表达式完全指南
爬取豆瓣Top250图书数据
shp 地图文件批量添加字段
爬虫小试牛刀(爬取学校通知公告)
【python基础】函数-初识函数
【python基础】函数-返回值
HTTP请求:requests模块基础使用必知必会
Python初学者友好丨详解参数传递类型
如何有效管理爬虫流量?
SQL SERVER中递归
2个场景实例讲解GaussDB(DWS)基表统计信息估
常用的 SQL Server 关键字及其含义
动手分析SQL Server中的事务中使用的锁
openGauss内核分析:SQL by pass & 经典执行
一招教你如何高效批量导入与更新数据
天天写SQL,这些神奇的特性你知道吗?
openGauss内核分析:执行计划生成
[IM002]Navicat ODBC驱动器管理器 未发现数据
初入Sql Server 之 存储过程的简单使用
这是目前我见过最好的跨域解决方案!
减少回流与重绘
减少回流与重绘
如何使用KrpanoToolJS在浏览器切图
performance.now() 与 Date.now() 对比
一款纯 JS 实现的轻量化图片编辑器
关于开发 VS Code 插件遇到的 workbench.scm.
前端设计模式——观察者模式
前端设计模式——中介者模式
创建型-原型模式