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

一个网络抓取的程序,发现过了一会,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哈哈哈~

你可能感兴趣的:(String,正则表达式,网络,工具,代码分析,2010)