正则表达式中的反向引用

1.反向引用需要使用到分组,分组就是使用()括起来的部分为一个整体,在进行分组匹配时的原则是:由外向内,由左向右


2.反向引用如:1,2等
          1:表示的是引用第一次匹配到的()括起来的部分
          2:表示的是引用第二次匹配到的()括起来的部分
 
          (1)例:
               String regex = "^(\d)\1$";
               首先这里是匹配两位,d一位,1又引用d一位 这里的1会去引用(d)匹配到的内容,因为(d)是第一次匹配到的内容。
              如:str = "22"时,(\d)匹配到2,所以1引用(\d)的值也为2,所以str="22"能匹配
                    str = "23"时,(\d)匹配到2,因为1引用(\d)的值2,而这里是3,所以str="23"不能匹配
          (2)例:
               String regex = "^(\d)\1[0-9](d)1{2}";
               注意在后面第二个(d)1{2}中的1,这里的1并不会去匹配他前面的(d),而是匹配第一个(\d),
               如:第一个(d)为3时,则第一个1也为3,同样最后那个1也为3,所以结果可以是335933,332533
                    而不是336444,339888
             
 
          (3)例:
               String regex = " ^(d)1[0-9](d)2{2}$";
               这里使用了2引用第二次匹配到的分组,这里第二次匹配的分组为2前面的(d), 这里的{2}指的是2的值出现两次
               如:第一个(d)为4时,1引用第1个(d)也为4,第二个(d)为5时,2引用第二个(d)为5,所以结果可以是:447555,440222
          
          
          
 
          (4)例:
               String regex = " ^((d)3)1[0-9](d)2{2}$";
               当匹配中的分组有嵌套时,是从外向里匹配的,其次在由左向右匹配
               这里主要是分析匹配到分组的顺序,首先匹配((d)3)这整个部分,其次匹配((d)3)里面的(d),第三次匹配时最后一个2前面的(d)
               如:如((d)3)中的(d)为2时,((d)3)的值为23,此时1为((d)3)的值1,而2引用((d)3)中的(d)的值3,第三个(d)为5时,此时3引用第三个(d)的值5,所以结果可以有:23238522,23230522,
          
               
原文地址:https://www.cnblogs.com/1549983239yifeng/p/14067260.html