频道栏目
首页 > 资讯 > Java > 正文

java正则表达式 match、find匹配位置

15-06-11        来源:[db:作者]  
收藏   我要投稿

如题,对于java正则表达式这几个方法匹配一次后的,匹配位置搞不太清楚,就写了几个例子。如下:

 

  String ss="ooaaoo";
        Pattern pt=Pattern.compile("(o+)");
        Matcher mt=pt.matcher(ss);
       // mt.lookingAt();
       // mt.matches();
        while(mt.find()){
        	System.out.println(mt.group(1)+"|||"+mt.start());
        }

这个结果很明显会匹配二次,一次在0位置,一次在4位置。

 

看下面的代码

  String ss="ooaaoo";
        Pattern pt=Pattern.compile("(o+)");
        Matcher mt=pt.matcher(ss);
           mt.lookingAt();
       // mt.matches();
        while(mt.find()){
        	System.out.println(mt.group(1)+"|||"+mt.start());
        }
当我们把matches或lookingat方法之一的注释拿掉之后,只会发生一次匹配,就是在4位置。

 

再看下面的代码:

 

String ss="aaooaaoo";
        Pattern pt=Pattern.compile("(o+)");
        Matcher mt=pt.matcher(ss);
          mt.lookingAt();
       // mt.matches();
        while(mt.find()){
        	System.out.println(mt.group(1)+"|||"+mt.start());
        }
我们的输入字符串ss发生了变化。这个程序结果会发生二次匹配,一次在2位置,一次在4位置。

 

所以可得出以下结论:

1.当我们的输入字符串ss开头不匹配正则表达式的时候,matches和lookingat都不影响下次匹配位置。

2.如果输入字符串开头匹配正则表达式,调用matches或lookingat之后,下一次匹配的位置,会在去掉开头匹配的字符串之后。
 

相关TAG标签
上一篇:c++ new 和 delete
下一篇:字符串全排列的递归实现
相关文章
图文推荐

关于我们 | 联系我们 | 广告服务 | 投资合作 | 版权申明 | 在线帮助 | 网站地图 | 作品发布 | Vip技术培训 | 举报中心

版权所有: 红黑联盟--致力于做实用的IT技术学习网站