正则表达式性能问题

之前在web程序中错误的使用了RegexOptions.Compiled 选项,导致每个页面打开整度慢了接近0.5秒..
因为是在httpModule里过滤关键字,对性能比较敏感,做了个简单测试.


           Stopwatch w  =   new  Stopwatch();
           w.Start();
           Regex r 
=   new  Regex( @" .* " , RegexOptions.Compiled );
             Match m 
=  r.Match( " aaa " );
             
if  (m.Success)
             {
                 w.Stop();
                 Response.Write(w.Elapsed.TotalSeconds.ToString(
" 0.0000000 " ));
              
             }

不加RegexOptions.Compiled ,计时器显示0.0000x,添加RegexOptions.Compiled 后计数器显示0.00x
如果正则式写的在复杂一些,那么仅编译时间都要0.x秒了. 看来大部分应用使用RegexOptions.Compiled 反而会降低性能,除非是很BT的应用

.net的正则表达使用NFA引擎,NFA引擎正则式的写法对性能的很大. 


 Regex r = new Regex(@"(a|[^a]+)*^" );
 string  str="111111111111111111111111111111111";
Match m = r.Match(str);
             if (m.Success)
             {
                 Response.Write(w.Elapsed.TotalSeconds.ToString("0.0000000"));
              
             }
只要str长度超过26基本上很匹配难完成.
以下这些都类似
(b|[^b]+)*^
(c|[^c]+)*^
 (^|[^^]+)*(^|[^^]+)*^ 
(^|[^^]+|[^^]*)*^
看来正则的写法对性能影响挺大的

之前发布一个正则测试器,开源了,也没时间更新,写的比较乱了
http://www.cnblogs.com/windinwing/archive/2009/04/16/1436902.html

点击下载

转载于:https://www.cnblogs.com/windinwing/archive/2009/08/19/1549739.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值