强调在正则中只要单纯用了括号就会有捕获分组保存

前言:
本篇文章主要为了强调正则中\1的引用,1为括号的编号。和不加不必要的括号,以防影响效率。

例子1

import java.util.regex.Pattern;
import java.util.regex.Matcher;

public class pa14{
    public static void main(String args[]){
        String sta="hello 123 hello";
        String regex="(\\w+)\\s+(\\d+)\\s+(\\1)";
        Pattern pattern=Pattern.compile(regex);
        Matcher matcher=pattern.matcher(sta);

        if(matcher.find()){
            System.out.println("匹配成功!!");
            System.out.println("获取编号0的匹配字符:["+matcher.group(0)+"]");
            System.out.println("获取编号1的匹配字符:["+matcher.group(1)+"]");
            System.out.println("获取编号2的匹配字符:["+matcher.group(2)+"]");
            System.out.println("获取编号3的匹配字符:["+matcher.group(3)+"]");
        }
    }
}

运行结果:

匹配成功!!
获取编号0的匹配字符:[hello 123 hello]
获取编号1的匹配字符:[hello]
获取编号2的匹配字符:[123]
获取编号3的匹配字符:[hello]

例子2

import java.util.regex.Pattern;
import java.util.regex.Matcher;

public class pa14{
    public static void main(String args[]){
        String sta="hello 123 hello";
        String regex="(\\w+)\\s+(\\d+)\\s+\\1";
        Pattern pattern=Pattern.compile(regex);
        Matcher matcher=pattern.matcher(sta);

        if(matcher.find()){
            System.out.println("匹配成功!!");
            System.out.println("获取编号0的匹配字符:["+matcher.group(0)+"]");
            System.out.println("获取编号1的匹配字符:["+matcher.group(1)+"]");
            System.out.println("获取编号2的匹配字符:["+matcher.group(2)+"]");
            //System.out.println("获取编号3的匹配字符:["+matcher.group(3)+"]");
            //如果把编号3放开就会报越界异常
        }
    }
}

运行结果:

匹配成功!!
获取编号0的匹配字符:[hello 123 hello]
获取编号1的匹配字符:[hello]
获取编号2的匹配字符:[123]

在上面这两个例子中,例子1的”//1”外面多加了括号所以,就多了捕获分组,并且保存了捕获分组结果。
然而加这个括号往往是多余的。因为//1已经可以正确表示第一个捕获分组的结果了。就不需要再多加个括号。

然而想要多加个括号也可以:
看例子:

import java.util.regex.Pattern;
import java.util.regex.Matcher;

public class pa14{
    public static void main(String args[]){
        String sta="hello 123 hello";
        String regex="(\\w+)\\s+(\\d+)\\s+(?:\\1)";
        Pattern pattern=Pattern.compile(regex);
        Matcher matcher=pattern.matcher(sta);

        if(matcher.find()){
            System.out.println("匹配成功!!");
            System.out.println("获取编号0的匹配字符:["+matcher.group(0)+"]");
            System.out.println("获取编号1的匹配字符:["+matcher.group(1)+"]");
            System.out.println("获取编号2的匹配字符:["+matcher.group(2)+"]");
            //System.out.println("获取编号3的匹配字符:["+matcher.group(3)+"]");
            //同样,把编号3的放开也会报越界异常
        }
    }
}

运行结果:

匹配成功!!
获取编号0的匹配字符:[hello 123 hello]
获取编号1的匹配字符:[hello]
获取编号2的匹配字符:[123]

总结,不用的括号一定要去掉,否者影响正则的匹配效率,因为括号会保存捕获分组,这样不仅耗费内存也耗费时间。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值