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