zoukankan      html  css  js  c++  java
  • 【正则表达式】(.+)和(.+?)的区别

    1、符号释义

    ① ()  分组符,把括号内的字符当成一个整体处理。

    ②   与换行符外的字符都匹配,针对单字符。

    + 前一字符必须存在,可以重复1次或更多次

    ④ 跟在子串后,表示匹配前面的子串1次或0次,即前一字符可以存在也可以不存在,但是存在只能有一次;

            跟在*、+、?后,表示进入非贪婪模式,也称为惰性模式。

    2、贪婪/非贪婪模式

    *正则默认贪婪模式

    贪婪模式

    尽可能匹配最长的字符串。贪婪匹配是先看整体字符串是否匹配,如果不匹配,它会去掉字符串中的最后一个字符再次尝试匹配。以此循环,直至匹配成功。

    非贪婪模式

    尽可能匹配最短的字符串。惰性匹配是从左侧第一个字符向右匹配,先看是否匹配,若不匹配,就加入右侧下一个字符再次尝试匹配。以此循环,直至匹配成功。

    3、实例

    存在字符串"<1><123>"

    ①正则表达式<(.+)>表示尽可能匹配最长的符合规则<字符串>的内容,最终返回"<1><123>"

    ②正则表达式<(.+?)>表示尽可能匹配最短的符合规则<字符串>的内容,最终返回"<1>"

  • 相关阅读:
    BZOJ3781 小B的询问
    BZOJ3757 苹果树
    BZOJ1491 [NOI2007]社交网络
    BZOJ3754 Tree之最小方差树
    BZOJ1251 序列终结者
    BZOJ2259 [Oibh]新型计算机
    BZOJ1043 [HAOI2008]下落的圆盘
    D. 预定义变量
    A. 变量命名原则
    B. PHP变量的特点
  • 原文地址:https://www.cnblogs.com/12345zjl/p/15628090.html
Copyright © 2011-2022 走看看