一篇关于Matcher find方法深刻理解的文章
知识点
find
首先find和matchs是不一样的,matchs是将字符串从开头到结尾,进行匹配,匹配成功即为true,反之为false,find是字符串的部分如果匹配成功即为true,反之即为false。
find匹配的正则如果在字符串中有多处能够匹配上,可以理解为将字符串分割成了多块。
通过代码,可以看到find()每执行一次之后,下次在执行就会从上次匹配到的字符串的下一个字符开始匹配
find(int var1)
指定从第几个索引处开始检索、匹配,在这个操作之前进行了reset操作。
reset
将find方法的相关参数进行初始化,这样再次find()就不是从上次匹配的字符串下一个字符开始匹配了,而是从第一个字符处开始匹配
group(int var1)
返回find到的第几个片段
源码
public boolean find() {
int var1 = this.last;
if (var1 == this.first) {
++var1;
}
if (var1 < this.from) {
var1 = this.from;
}
if (var1 <= this.to) {
return this.search(var1);
} else {
for(int var2 = 0; var2 < this.groups.length; ++var2) {
this.groups[var2] = -1;
}
return false;
}
}
public boolean find(int var1) {
int var2 = this.getTextLength();
if (var1 >= 0 && var1 <= var2) {
this.reset();
return this.search(var1);
} else {
throw new IndexOutOfBoundsException("Illegal start index");
}
}
public Matcher reset() {
this.first = -1;
this.last = 0;
this.oldLast = -1;
int var1;
for(var1 = 0; var1 < this.groups.length; ++var1) {
this.groups[var1] = -1;
}
for(var1 = 0; var1 < this.locals.length; ++var1) {
this.locals[var1] = -1;
}
this.lastAppendPosition = 0;
this.from = 0;
this.to = this.getTextLength();
return this;
}
public String group() {
return this.group(0);
}
public String group(int var1) {
if (this.first < 0) {
throw new IllegalStateException("No match found");
} else if (var1 >= 0 && var1 <= this.groupCount()) {
return this.groups[var1 * 2] != -1 && this.groups[var1 * 2 + 1] != -1 ? this.getSubSequence(this.groups[var1 * 2], this.groups[var1 * 2 + 1]).toString() : null;
} else {
throw new IndexOutOfBoundsException("No group " + var1);
}
}
故事是这样的
Matcher matcher = p.matcher(myURLValue.toString());
Matcher matcher2 = p2.matcher(myURLValue.toString());
log.debug("matcher.find()---------------------------------------,%s",matcher.find());
log.debug("matcher2.find()---------------------------------------,%s",matcher2.find());
if ( matcher.find()){
log.debug("matcher");
}else if (matcher2.find()){
log.debug("matcher2");
}
tip:工作中关于业务的代码已经省去,这几行足以说明问题~
上图的运行结果是什么???
matcher.find()---------------------------------------,true
matcher.find()---------------------------------------,false
没了
为什么???
就算有一个是true至少会输出下面的任意一个matcher或者matcher2把。
探索
我都怀疑if和else if里面都是false,于是傻傻的直接将if和else if里面的判断条件设为了true,发现结果是正确的,说明上面例子中的if和else if里面都是false。
问题解决
方法一:
Matcher matcher = p.matcher(myURLValue.toString());
Matcher matcher2 = p2.matcher(myURLValue.toString());
log.debug("matcher.find()---------------------------------------,%s",matcher.find());
log.debug("matcher2.find()---------------------------------------,%s",matcher2.find());
matcher.reset();
matcher2.reset();
if ( matcher.find()){
log.debug("matcher");
}else if (matcher2.find()){
log.debug("matcher2");
}
方法二:
Matcher matcher = p.matcher(myURLValue.toString());
Matcher matcher2 = p2.matcher(myURLValue.toString());
if ( matcher.find()){
log.debug("matcher");
}else if (matcher2.find()){
log.debug("matcher2");
}
方法三:
Matcher matcher = p.matcher(myURLValue.toString());
Matcher matcher2 = p2.matcher(myURLValue.toString());
log.debug("matcher.find()---------------------------------------,%s",matcher.find());
log.debug("matcher2.find()---------------------------------------,%s",matcher2.find());
if ( matcher.find(1)){
log.debug("matcher");
}else if (matcher2.find(1)){
log.debug("matcher2");
}
总结
可以看到我的问题是出在,打了两个debug,执行过一次find方法,索引从第一次匹配的下一个开始,因为我的字符串中只有一个片段能够和正则匹配,所以下次if或者else if的时候是都是false的。
解决的办法就是要么reset初始化一下,要么删除掉debug那两行,要么就用有参的find方法,指定从第几个开始检索。
一篇关于Matcher find方法深刻理解的文章的更多相关文章
- lucene-一篇分词器介绍很好理解的文章
本文来自这里在前面的概念介绍中我们已经知道了分析器的作用,就是把句子按照语义切分成一个个词语.英文切分已经有了很成熟的分析器: StandardAnalyzer,很多情况下StandardAnalyz ...
- [转]深刻理解Python中的元类(metaclass)以及元类实现单例模式
使用元类 深刻理解Python中的元类(metaclass)以及元类实现单例模式 在看一些框架源代码的过程中碰到很多元类的实例,看起来很吃力很晦涩:在看python cookbook中关于元类创建单例 ...
- Atitit 图像处理 深刻理解梯度原理计算.v1 qc8
Atitit 图像处理 深刻理解梯度原理计算.v1 qc8 1.1. 图像处理 梯度计算 基本梯度 内部梯度 外部梯度 方向梯度1 2. 图像梯度就是图像边缘吗?2 1.1. 图像处理 梯度计算 ...
- 转载:JAVA中关于set()和get()方法的理解及使用
对于JAVA初学者来说,set和get这两个方法似乎已经很熟悉了,这两个方法是JAVA变成中的基本用法,也是出现频率相当高的两个方法. 为了让JAVA初学者能更好的理解这两个方法的使用和意义,今天笔者 ...
- javamail模拟邮箱功能--邮件删除-中级实战篇【邮件标记方法】(javamail API电子邮件实例)
前言: JavaMail jar包下载地址:http://java.sun.com/products/javamail/downloads/index.html 本章可能是讲解javamail的最后一 ...
- 深刻理解Java中final的作用(一):从final的作用剖析String被设计成不可变类的深层原因
声明:本博客为原创博客,未经同意,不得转载!小伙伴们假设是在别的地方看到的话,建议还是来csdn上看吧(原文链接为http://blog.csdn.net/bettarwang/article/det ...
- java中set和get方法的理解
对于JAVA初学者来说,set和get这两个方法似乎已经很熟悉了,这两个方法是JAVA变成中的基本用法,也是出现频率相当高的两个方法. 为了让JAVA初学者能更好的理解这两个方法的使用和意义,今天笔者 ...
- 深刻理解iosBlock
深刻理解iosBlock ///一个控制器里的方法 - (void)setRefreshHeader { ACWeakSelf(self); self.tableView.mj_header = [M ...
- javascript 面向对象程序设计--深刻理解对象
javascript中,每个对象都是基于一个引用类型创建的,我们可以把ECMAScript 的对象想象成散列表:无非就是一组名值对,其中值可以是数据或函数. 深刻理解对象 创建自定义对象的最简单方式就 ...
随机推荐
- Windows的ODBC配置指南: MySQL, PostgreSQL, DB2, Oracle
MySQL- 官网: https://dev.mysql.com/downloads/connector/odbc/- 安装: * msi格式, 直接安装即可 * zip格式, 解压缩, 命令行(管理 ...
- ajax-jq
<!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...
- PKUSC订正
Day1 T2:最大前缀和 枚举答案集合(不直接枚举答案数,相当于状态的离散化),这个集合成为答案当且仅当存在方案使得答案集合的排列后缀和>=0(如果<0就可以去掉显然更优),答案补集的前 ...
- 报错 DOMDocument not found
php -m 查看有没有dom扩展 没有安装扩展 yum install php-dom php 常用扩展有 yum install php-solr php-opcache php-seasLog ...
- 解析Spring第四天(Spring中的事物、Spring框架来管理模板类)
JDBC模板技术: Spring框架中提供了很多持久层的模板类来简化编程,使用模板类编写程序会变的简单 template 模板 都是Spring框架提供XxxTemplate 提供了JDBC模板,Sp ...
- 单独编译和使用webrtc音频回声消除模块(附完整源码+测试音频文件)
单独编译和使用webrtc音频降噪模块(附完整源码+测试音频文件) 单独编译和使用webrtc音频增益模块(附完整源码+测试音频文件) 说实话很不想写这篇文章,因为这和我一贯推崇的最好全部编译并使用w ...
- C语言itoa()函数和atoi()函数详解(整数转字符C实现)【转载】
文章转载自https://www.cnblogs.com/bluestorm/p/3168719.html C语言提供了几个标准库函数,可以将任意类型(整型.长整型.浮点型等)的数字转换为字符串. ...
- NX二次开发-设置WCS显示UF_CSYS_set_wcs_display
NX9+VS2012 #include <uf.h> #include <uf_csys.h> UF_initialize(); //设置WCS显示 //1显示WCS, 0不显 ...
- NX二次开发-UFUN拾取向量对话框UF_UI_specify_vector
#include <uf.h> #include <uf_ui.h> UF_initialize(); //拾取向量对话框 ], pnt[]; int mode = UF_UI ...
- 其它课程中的python---4、Matplotlib最最最最简单使用
其它课程中的python---4.Matplotlib最最最最简单使用 一.总结 一句话总结: 慢慢来吧,不着急,心态平和和沉稳:每次和世界交互,你就能感受到无比的自信 1.如何区别python2和p ...