先扫盲一下什么是正则表达式的贪婪,什么是非贪婪?或者说什么是匹配优先量词,什么是忽略优先量词?

好吧,我也不知道概念是什么,来举个例子吧。

某同学想过滤之间的内容,那是这么写正则以及程序的。

$str = preg_replace('%%i','',$str);//非贪婪

看起来,好像没什么问题,其实则不然。若

$str = '>alert(document.cookie)';

那么经过上面的程序处理,其结果为

$str = '>alert(document.cookie)';

$str = preg_replace('%%i','',$str);//非贪婪

print_r($str);

//$str 输出为

仍然达不到他想要的效果。上面的就是非贪婪,也有的叫惰性。其标志非贪婪的标识为量数元字符后面加? ,比如 +?、*?、??(比较特殊,以后的BLOG中,我会写到)等。即标识非贪婪,如果不写?就是贪婪。比如

$str = '>alert(document.cookie)';

$str = preg_replace('%%i','',$str);//非贪婪

print_r($str);

//$str 输出为

正则表达式为\w*(\d+),字符串为cfc456n,那么,这个正则匹配的$1是多少??

如果您回答是 456,那么,恭喜你,回答错了,其结果不是456,而是6,您知道为什么吗?

CFC4N来解释一下,当正则引擎用正则\w*(\d+)去匹配字符串cfc456n时,会先用\w*去匹配字符串cfc456n,首先,\w*会匹配字符串cfc456n的所有字符,然后再交给\d+去匹配剩下的字符串,而剩下的没了,这时,\w*规则会不情愿的吐出一个字符,给\d+去匹配,同时,在吐出字符之前,记录一个点,这个点,就是用于回溯的点,然后\d+去匹配n,发现并不能匹配成功,会再次要求\w*再吐出一个字符,\w*会先再次记录一个回溯的点,再吐出一个字符。这时,\w* 匹配的结果只有cfc45了,已经吐出6n了,\d+再去匹配6,发现匹配成功,则会通知引擎,匹配成功了,就直接显示出来了。所以,(\d+)的结果是6,而不是456。

当上面的正则表达式改为 \w*?(\d+)(注意,此处为非贪婪),字符串仍然为cfc456n,那么,这时候,正则匹配的$1是多少??

甲同学回答:结果是 456。

嗯,是的,正确,是456,CFC4N弱弱的问下,为什么是456 呢?

我在来解释一下 为什么是456

正则表达式有条规则,是量词优先匹配,所以\w*?会先去匹配字符串cfc456,由于\w*?是非贪婪,正则引擎会用表达式\w+?每次仅匹配一个字符串,然后再将控制权交给后面的\d+去匹配下一个字符,同时,记录一个点,用于在匹配不成功的时候,返回这里,再次匹配,也就是回溯点。由于\w后面是量词是*,*表示0到无数次,所以,首先是0次,也就是\w*?匹配个空,记录回溯点,将控制权交给\d+,\d+去匹配cfc456n的第一个字符c,然后,匹配失败,于是乎,接着讲控制权交给\w*?去匹配cfc456n的c,\w*?匹配c成功,由于是非贪婪,所以,他每次只匹配一个字符,记录回溯点,然后再将控制权交给\d+匹配f,接着,\d+匹配f再失败,再把控制权给\w*?,\w*?再匹配c,记录回溯点(这时\w*?匹配结果是cfc了),再把控制权给\d+,\d+去匹配4,匹配成功,然后,由于量词是+,就是1到无数次,所以,接着往后匹配,再匹配5,成功,再接着,再匹配6,成功,再接着,继续匹配操作,下一个字符是n,匹配失败,这时,\d+会吧控制权交出去。由于\d+后面已经没有正则表达式了,所以,整个正则表达式宣告匹配完成,其结果就是 cfc456, 其中第一组结果是456。亲爱的同学,您明白刚刚的题目的结果,为什么是456了吗?

好了,您是否从上面的例子了解了贪婪,非贪婪的匹配原理了?那您是否明白您在什么时候需要使用贪婪,非贪婪去处理您的字符串了?

鸟哥的文章里讲到针对表达式、程序为

$reg = "/

$str = ""; //长度大于100014

$ret = preg_repalce($reg, "", $str); //返回NULL

其原因就是回溯太多了,直到造成耗尽栈空间爆栈。

再来看个例子。

字符串

$str = '';

正则表达式为

$strRegex1 = '%

$strRegex2 = '%

$strRegex3 = '%

php 正则 回溯,php 正则表达式效率 贪婪、非贪婪与回溯分析相关推荐

  1. php正则表达式非贪婪,php正则表达式中的非贪婪模式匹配

    php正则表达式中的非贪婪模式匹配 一般情况下,正则表达式的匹配是贪婪模式的,比如下面这个例子: 字符串:....src="http://www.bloghome.cn/1.mp3" ...

  2. python正则表达式贪婪匹配_Python正则表达式教程之三:贪婪/非贪婪特性

    之前已经简单介绍了Python正则表达式的基础与捕获,那么在这一篇文章里,我将总结一下正则表达式的贪婪/非贪婪特性. 贪婪 默认情况下,正则表达式将进行贪婪匹配.所谓"贪婪",其实 ...

  3. 正则表达式——贪婪非贪婪模式

    贪婪与非贪婪模式影响的是被量词修饰的子表达式的匹配行为,贪婪模式在整个表达式匹配成功的前提下,尽可能多的匹配,而非贪婪模式在整个表达式匹配成功的前提下,尽可能少的匹配.非贪婪模式只被部分NFA引擎所支 ...

  4. python贪婪与非贪婪_python 贪婪 非贪婪 匹配

    python re模块还是需要重新学习. python readline 和 readlines(), readline() , read() 3者之间的区分,之前1直都不清楚,现在弄清楚是怎样回事了 ...

  5. python 贪婪 非贪婪 匹配

    python 中的正则是匹配换行以外的所有的字符..* 是匹配不了所有的字符的.在某些情况下,我的结论是正确的,但是在某些情况下,我的结论又是错误的.刚才遇到的问题,现在终于知道是怎么回事了,原来是贪 ...

  6. 正则表达式口诀及常用正则 。正则贪婪与非贪婪模式

    正则表达式口诀及常用正则 签于网上太多的介绍都是一篇凶悍的短文,边看边理解可以,帮助记忆不行.又受五笔字型字根表口诀"白手看头三二斤..."的启发,  试作"正则表达式助 ...

  7. 正则表达式之 贪婪与非贪婪模式详解

    1 概述 贪婪与非贪婪模式影响的是被量词修饰的子表达式的匹配行为,贪婪模式在整个表达式匹配成功的前提下,尽可能多的匹配,而非贪婪模式在整个表达式匹配成功的前提下,尽可能少的匹配.非贪婪模式只被部分NF ...

  8. 转:正则表达式之 贪婪与非贪婪模式详解

    1 概述 贪婪与非贪婪模式影响的是被量词修饰的子表达式的匹配行为,贪婪模式在整个表达式匹配成功的前提下,尽可能多的匹配,而非贪婪模式在整个表达式匹配成功的前提下,尽可能少的匹配.非贪婪模式只被部分NF ...

  9. 正则之贪婪和非贪婪(惰性)模式

    前言 阅读此文章之前建议先了解常用正则特殊字符 贪婪模式的量词,也叫匹配优先量词,包括: "?"."*"."+"."{n,}&qu ...

最新文章

  1. 网站优化必知的五大发文注意事项
  2. Day 30: Play Framework —— Java开发者的梦想框架
  3. 串的定长存储表示【数据结构】
  4. ASP.NET MVC TagBuilder使用
  5. excel中最常用的30个函数_94个Excel常用函数目录
  6. [译] JAVA初学者的30个常见问题
  7. java mac 怎么删_做java服务器开发,并发布到linux,那MacBookPro开发是绝佳工具
  8. C# WPF 生成随机数添加到DataGrid表格
  9. 计算机缺失esul.dll,msedgeupdateres_es.dll
  10. 卷积自编码器_GCLGP | 图卷积高斯过程
  11. 腾云驾雾了解Windows10和微软私有云
  12. PPT修改母版页码(亲测可用)
  13. 三、Android开启wifi热点
  14. 怎么起用计算机无线开关,笔记本无线网络开关,详细教您如何打开笔记本电脑无线网卡开关...
  15. Ajax访问接口报错NET::ERR_CERT_REVOKED
  16. 微软认知服务应用秘籍 – 君子动口不动手
  17. win10解决设置默认打开方式不生效问题
  18. 这一季绿色智能制造“英雄联盟”已集结, 有哪些新鲜点?
  19. 你看天上那朵云,像不像我借你的2万?
  20. step5.游戏窗口的初始化

热门文章

  1. springboot java获取版本号_深入实践Spring Boot 实战篇,大佬整理出的PDF文档
  2. java readline 超时_跳过Java中的BufferedReader readLine()方法
  3. [精品]CSAPP Bomb Lab 解题报告(五)
  4. matlab小波脊线,小波脊线提取,模极大值法。运行的结果不太对,代码有些地方我也没完全看懂...
  5. 误码率越高越好还是越低越好_ISO永远都是越低越好?不一定!这些情况下要用高 ISO!...
  6. cordic ip核 vivado_Xilinx Vivado CORDIC IP求解atan 反正切
  7. python皮卡丘编程代码_再接再厉,用python编程13行代码解方程组(纯字符)
  8. Java编程字符逆序输出_用JAVA编写一程序:从键盘输入多个字符串到程序中,并将它们按逆序输出在屏幕上。...
  9. 无人值守安装之cdrom_无人值守安装
  10. CMDB学习之三数据采集