博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
贪婪与非贪婪模式
阅读量:7110 次
发布时间:2019-06-28

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

【匹配次数中的贪婪与非贪婪】

在使用修饰匹配次数的特殊符号时,有几种表示方法可以使同一个表达式能够匹配不同的次数,比如:"{m,n}", "{m,}", "?", "*","+",具体匹配的次数随被匹配的字符串而定。这种重复匹配不定次数的表达式在匹配过程中,总是尽可能多的匹配。比如,针对文本"dxxxdxxxd",举例如下:

由此可见,"/w+" 在匹配的时候,总是尽可能多的匹配符合它规则的字符。虽然第二个举例中,它没有匹配最后一个 "d",但那也是为了让整个表达式能够匹配成功。同理,带 "*" 和 "{m,n}" 的表达式都是尽可能地多匹配,带 "?" 的表达式在可匹配可不匹配的时候,也是尽可能的 "要匹配"。这 种匹配原则就叫作 "贪婪" 模式

 

非贪婪模式:

在修饰匹配次数的特殊符号后再加上一个 "?" 号,则可以使匹配次数不定的表达式尽可能少的匹配,使可匹配可不匹配的表达式,尽可能的 "不匹配"。这种匹配原则叫作 "非贪婪" 模式,也叫作 "勉强"模式。如果少匹配就会导致整个表达式匹配失败的时候,与贪婪模式类似,非贪婪模式会最小限度的再匹配一些,以使整个表达式匹配成功。举例如下,针对文本 "dxxxdxxxd" 举例:

举例如下:

 

举例 1:

表达式 "<td>(.*)</td>" 与字符串 "<td><p>aa</p></td><td><p>bb</p></td>" 匹配时,匹配的结果是:成功;匹配到的内容是 "<td><p>aa</p></td> <td><p>bb</p></td>" 整个字符串, 表达式中的 "</td>" 将与字符串中最后一个 "</td>" 匹配。

 

举例 2:

相比之下,表达式 "<td>(.*?)</td>" 匹配举例 1 中同样的字符串时,将只得到 "<td><p>aa</p></td>", 再次匹配下一个时,可以得到第二个 "<td><p>bb</p></td>"。

 

转载于:https://www.cnblogs.com/zhzcode/p/9782644.html

你可能感兴趣的文章
S3C2410 实验三——块拷贝、字拷贝(寄存器的理解)
查看>>
关于2014
查看>>
iOS web remote debug 正确的姿势
查看>>
MapGuide open source开发心得一:简介
查看>>
[转]ASP.NET 2.0 本地化功能:本地化 Web 应用程序的新方法
查看>>
ORACLE函数大全(CSDN)
查看>>
json概念
查看>>
MVC使用Gantt Chart实现甘特图,管理事情进度
查看>>
FIREDAC字段类型映射
查看>>
Visual studio 2019 preview & C# 8 initial experience
查看>>
Delphi XE中String、ANSIString、TBytes之间的转换
查看>>
《ASP.NET AJAX程序设计 I、II、III卷》的新封面效果
查看>>
八款开源 Android 游戏引擎 (巨好的资源)
查看>>
JQuery实现全选、取消全选、反向选择
查看>>
关于重写equals,hashcode以及compareTo方法!
查看>>
iPhone游戏编程实例:分享成功游戏开发人员的锦囊妙计
查看>>
POJ 3744 Scout YYF I(概率+矩阵)
查看>>
Fluent NHibernate and Mysql,SQLite,PostgreSQL
查看>>
外部排序
查看>>
CComObject 。。。(转)
查看>>