博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
正则表达式:贪婪模式与懒惰模式
阅读量:3965 次
发布时间:2019-05-24

本文共 721 字,大约阅读时间需要 2 分钟。

一 语法区别

贪婪模式与懒惰模式的语法区别在于重复限定修饰符的后面是否有问号,有的话就是懒惰模式,否则就是贪婪模式。

二 例子

他所说的应该是贪婪量词,是先吃尽所有字符,然后再一个一个地吐出来,直接匹配成功为止

而懒惰量词,是从头开始一个字符一个字符地吃,直接匹配成功为止

我想其意思应该是贫婪是逐渐向前匹配,而懒惰是向后慢慢匹配吧

贪婪和懒惰的匹配过程是这样的:

懒惰是从左边一个一个地吃直到匹配为止,不加 ? 的是一口吃掉整个字符串,然后从最后一个一个地吐出来直到匹配为止

字符串

a=b=b===

a.*b 将匹配满足条件最长的字符串 a=b=b

工作方式:

首先将:a=b=b=== 全部吃掉,从右边一个一个地吐出来

  1. a=b=b=== 不匹配,吐出一字符
  2. a=b=b== 不匹配,再吐出一字符
  3. a=b=b= 不匹配,再吐出一字符
  4. a=b=b 匹配了,结束。如果再不匹配继续吐,直到没有字符了,匹配失败

a.*? 将匹配满足条件最短的字符串 a=====b

工作方式:

从左边一个一个地吃掉字符

  1. a 不能匹配表达式,继续吃
  2. a= 不能匹配表达式,继续吃
  3. a== 不能匹配表达式,继续吃
  4. a=== 不能匹配表达式,继续吃
  5. a==== 不能匹配表达式,继续吃
  6. a===== 不能匹配表达式,继续吃
  7. a=====b 呵呵,终于能匹配表达式了,匹配结束,匹配位置留于字符 b 后面,继续其他的匹配。如果不能匹配则一个一个地吃掉整个字符串直到吃完为止若还没有匹配则匹配失败。

3 参考URL:http://topic.csdn.net/u/20090917/17/ce6ec06c-2a3e-422f-88b8-40946e558c26.html

转载地址:http://xwyki.baihongyu.com/

你可能感兴趣的文章
Ubuntu 16.04开机隐藏菜单缩短时间
查看>>
《Linux内核设计与实现》- Linux的进程
查看>>
用户态切换到内核态的3种方式
查看>>
内核库函数
查看>>
Linux 系统内核空间与用户空间通信的实现与分析
查看>>
64位int类型用printf输出问题
查看>>
进程的状态转换
查看>>
如何查看进程的信息(线程数)
查看>>
Linux中的chage命令
查看>>
linux-详细解析密码文件passwd与shadow
查看>>
su- 与su的区别
查看>>
linux下发邮件mail
查看>>
echo如何手动输出换行
查看>>
身份证的正确使用方法——非常重要的知识
查看>>
ExtJS & Ajax
查看>>
Tomcat在Windows下的免安装配置
查看>>
JMeter常用测试元件
查看>>
JMeter——使用技巧
查看>>
Hibernate 实体层设计--Table per subclass
查看>>
Ruby解决方案:The 'ffi' native gem requires installed build tools ; 含最新DevKit下载地址
查看>>