国产探花免费观看_亚洲丰满少妇自慰呻吟_97日韩有码在线_资源在线日韩欧美_一区二区精品毛片,辰东完美世界有声小说,欢乐颂第一季,yy玄幻小说排行榜完本

首頁 > 編程 > Java > 正文

Java正則之貪婪匹配、惰性匹配

2019-11-26 15:15:01
字體:
來源:轉載
供稿:網友

貪婪量詞:

先看整個字符串是不是一個匹配。如果沒有發現匹配,它去掉最后字符串中的最后一個字符,并再次嘗試。如果還是沒有發現匹配,那么    再次去掉最后一個字符串,這個過程會一直重復直到發現一個匹配或者字符串不剩任何字符。簡單量詞都是貪婪量詞。

惰性量詞:

先看字符串中的第一個字母是不是一個匹配,如果單獨著一個字符還不夠,就讀入下一個字符,組成兩個字符的字符串。如果還沒有發現匹配,惰性量詞繼續從字符串中添加字符直到發現一個匹配或者整個字符串都檢查過也沒有匹配。惰性量詞和貪婪量詞的工作方式恰好相反。

支配量詞:

只嘗試匹配整個字符串。如果整個字符串不能產生匹配,不做進一步嘗試。

    貪婪量詞   惰性量詞    支配量詞                      描述
    -------------------------------------------------------------------------------------
      ?             ??             ?+                      可以出現0次或1次,但至多出現1次
      *             *?            *+                      可以出現任意次,也可以不出現
      +             +?            ++                      出現1次或多次,但至少出現1次
      {n}        {n}?           {n}+                   一定出現n次
      {n,m}    {n,m}?       {n,m}+               至少出現n次,但至多不能超過m次
      {n,}       {n,}?          {n,}+                 可以出現任意次,但至少出現n次
    例如:我們要從字符串abbbaabbbaaabbb1234中獲得abbb,aabbb,aaabbb的匹配

    1、貪婪量詞

復制代碼 代碼如下:

       var regexp = /.*bbb/g;
        var a = str.match(regexp);
        alert(a.length);   //output:1
        alert(a[0]);       //output:abbbaabbbaaabbb

    貪婪量詞的工作過程可以這樣表示:
      a)abbbaabbbaaabbb1234
      b)abbbaabbbaaabbb123
      c)abbbaabbbaaabbb12
      d)abbbaabbbaaabbb1
      e)abbbaabbbaaabbb //true
    可以看到,貪婪量詞在取得一次匹配后就會停止工作,雖然我們加了'g'(全局匹配)

    2、惰性量詞

復制代碼 代碼如下:

        var regexp = /.*?bbb/g;
        var a = str.match(regexp);
        alert(a.length);   //output:3
        alert(a[0]);       //output:abbb
        alert(a[1]);       //output:aabbb
        alert(a[2]);       //output:aaabbb

    惰性量詞的工作過程可以這樣表示:
      a)a
      b)ab
      c)abb
      d)abbb //保存結果,并從下一個位置重新開始
 
      e)a
      f)aa
      g)aab
      h)aabb
      j)aabbb //保存結果,并從下一個位置重新開始
 
      e)a
      e)aa
      e)aaa
      e)aaab
      e)aaabb
      e)aaabbb  //保存結果,并從下一個位置重新開始
    由于JS是不支持支配量詞的,所以支配量詞我們只能用JAVA來演示:

復制代碼 代碼如下:

        String string = "abbbaabbbaaabbb1234";
        Pattern p = Pattern.compile(".*+bbb");
        Matcher m = p.matcher(string);
        System.out.println(m.find());   //output:false

    因為支配量詞采用一刀切的匹配方式,如:
    a)abbbaabbbaaabbb1234 //false

以上所述就是本文的全部內容了,希望大家能夠喜歡,能夠對大家熟練掌握java正則匹配有所幫助。

請您花一點時間將文章分享給您的朋友或者留下評論。我們將會由衷感謝您的支持!

上一篇:淺談java封裝

下一篇:淺談Java三目運算

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 沧源| 翁源县| 桃园市| 昌都县| 民县| 白朗县| 黄平县| 汉川市| 镶黄旗| 专栏| 潼关县| 江西省| 新沂市| 错那县| 辽宁省| 当涂县| 莒南县| 民乐县| 枝江市| 平和县| 澜沧| 靖西县| 慈溪市| 兴仁县| 法库县| 临海市| 牟定县| 涟水县| 凌云县| 平凉市| 墨竹工卡县| 贵州省| 西吉县| 伊吾县| 岑溪市| 温州市| 西峡县| 深水埗区| 贵定县| 广西| 涟水县|