用“启动性能分析”找到了逻辑错误,开心啊

一个网络抓取的程序,发现过了一会,cpu就100%了,内存也逐渐变大,感觉这种网络读取用正则表达式提取字符串的程序不应该啊。

看代码分析了好半天,都感觉没有任何问题啊。

于是就用了vs2010的“启动性能分析”监视

程序过了一会100%cpu了

关掉程序

性能分析工具开始分析

等啊等啊

加载了好多符号

最后发现它说是由与Regex.IsMatch(String)这个函数占了99.6%的cpu

奇怪,难道线程太多字符串太多,Regex.IsMatch就卡了?

最后点了一个柱状的图,结果直接指向了一段代码

还是百思不得其解,那段代码很普通啊

                if (!regusername.IsMatch(neirong))
                    {
                        error.Enqueue(tie);
                        continue;

                    }

把这段代码去掉了再运行,发现不会100%了

于是我就看啊看啊

啊,发现啦就是那个continue;那个地方其实应该是break;因为continue结果造成了死循环,所以才100%

要不是用这玩意误打误撞怕是这个逻辑错误基本就找不到了

O(∩_∩)O哈哈哈~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值