令人苦恼的调试缓慢问题
之前的一个重要基础工程每次进入单步调试,总会在装载XML之后的解析工作时异常缓慢,往往需要7秒,而直接运行则只需要1秒,无论Debug还是Release.
后来一点点把代码注释,单步,注释再单步,终于确定了问题所在:
首先在一个重复运算的循环内部有如下语句:
var bPreDay = GetAttributeText("PreDay", "0").ToInt()>0;
此函数是一个扩展函数,实现如下:
public static string GetAttributeText(this XmlNode arg_node, string arg_strAttribute, string arg_strDefault = "")
{
var strRet = arg_strDefault;
try
{
return (arg_node.Attributes[arg_strAttribute] as XmlAttribute).InnerText;
}
catch (Exception ex)
{
}
return strRet;
}
这是一个老旧的历史代码,无疑其实现非常糟糕。竟然吞咽了异常!
此函数在初期书写时也许觉得可以不用判断,偷懒,结果不停重复调用时,由于arg_node.Attributes[arg_strAttribute]
返回null,造成此函数不停进入exception,消耗了大量时间资源。
我们现在将函数改为如下形式:
public static string GetAttributeText(this XmlNode arg_node, string arg_strAttribute, string arg_strDefault = "")
{
var attr = arg_node.Attributes[arg_strAttribute];
if (null == attr)
return arg_strDefault;
if (attr is XmlAttribute)
return (attr as XmlAttribute).InnerText;
else
throw new NotSupportedException();
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
· 葡萄城 AI 搜索升级:DeepSeek 加持,客户体验更智能