知识点

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方法深刻理解的文章的更多相关文章

  1. lucene-一篇分词器介绍很好理解的文章

    本文来自这里在前面的概念介绍中我们已经知道了分析器的作用,就是把句子按照语义切分成一个个词语.英文切分已经有了很成熟的分析器: StandardAnalyzer,很多情况下StandardAnalyz ...

  2. [转]深刻理解Python中的元类(metaclass)以及元类实现单例模式

    使用元类 深刻理解Python中的元类(metaclass)以及元类实现单例模式 在看一些框架源代码的过程中碰到很多元类的实例,看起来很吃力很晦涩:在看python cookbook中关于元类创建单例 ...

  3. Atitit 图像处理 深刻理解梯度原理计算.v1 qc8

    Atitit 图像处理 深刻理解梯度原理计算.v1 qc8 1.1. 图像处理  梯度计算  基本梯度 内部梯度 外部梯度 方向梯度1 2. 图像梯度就是图像边缘吗?2 1.1. 图像处理  梯度计算 ...

  4. 转载:JAVA中关于set()和get()方法的理解及使用

    对于JAVA初学者来说,set和get这两个方法似乎已经很熟悉了,这两个方法是JAVA变成中的基本用法,也是出现频率相当高的两个方法. 为了让JAVA初学者能更好的理解这两个方法的使用和意义,今天笔者 ...

  5. javamail模拟邮箱功能--邮件删除-中级实战篇【邮件标记方法】(javamail API电子邮件实例)

    前言: JavaMail jar包下载地址:http://java.sun.com/products/javamail/downloads/index.html 本章可能是讲解javamail的最后一 ...

  6. 深刻理解Java中final的作用(一):从final的作用剖析String被设计成不可变类的深层原因

    声明:本博客为原创博客,未经同意,不得转载!小伙伴们假设是在别的地方看到的话,建议还是来csdn上看吧(原文链接为http://blog.csdn.net/bettarwang/article/det ...

  7. java中set和get方法的理解

    对于JAVA初学者来说,set和get这两个方法似乎已经很熟悉了,这两个方法是JAVA变成中的基本用法,也是出现频率相当高的两个方法. 为了让JAVA初学者能更好的理解这两个方法的使用和意义,今天笔者 ...

  8. 深刻理解iosBlock

    深刻理解iosBlock ///一个控制器里的方法 - (void)setRefreshHeader { ACWeakSelf(self); self.tableView.mj_header = [M ...

  9. javascript 面向对象程序设计--深刻理解对象

    javascript中,每个对象都是基于一个引用类型创建的,我们可以把ECMAScript 的对象想象成散列表:无非就是一组名值对,其中值可以是数据或函数. 深刻理解对象 创建自定义对象的最简单方式就 ...

随机推荐

  1. Vue-cli开发笔记二----------接口调用、配置全局变量

    我做的一个项目,本身是没用任何框架,纯手写的前端及数据交互,项目已经完结.最近学Vue,于是借用这个项目,改装成vue项目. (一)接口问题:使用axios的调用方法,proxyTable解决开发环境 ...

  2. 实时监听input输入情况

    <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title> ...

  3. Eclipse+Marven + spring mvc 新建一个 Hello world 项目

    1. 打开Eclipse,菜单 File->New->Marven Project.               2. 点击 Next,                3. 选择 marv ...

  4. 在小程序中引入有赞的vant框架组件

    这里给大家讲解小程序中如何引入vant组件(我这里是采用小程序的云开发模板) 1.首先在项目的miniprogram文件夹右键在终端中打开,输入命令npm init初始化生成一个package.jso ...

  5. iptables开通某些端口

    #!/bin/bash #define all variance or parameter WAH_INT="eth0" WAH_INT_IP="222.222.101. ...

  6. DELPHI中如何闪烁应用程序窗口或任务栏按钮

    使用FlashWindowEx函数: 一.设置FlashWInfoDelphi中TFlashWInfo申明如下:TypeTFlashWInfo = record cbSize : LongInt; h ...

  7. NX二次开发-C++ DeleteFile删除文件实例代码

    NX9+VS2012 #include<Windows.h> DeleteFile("D:\\1\\test123.prt"); Caesar卢尚宇 2019年7月29 ...

  8. css Sticky footers

    写在前面 做过网页开发的同学想必都遇到过这样尴尬的排版问题:在主体内容不足够多或者未完全加载出来之前,就会导致出现(图一)的这种情况,原因是因为没有足够的垂直空间使得页脚推到浏览器窗口最底部.但是,我 ...

  9. POJ2226-Muddy Fields-二分图*

    目录 目录 思路: (有任何问题欢迎留言或私聊 && 欢迎交流讨论哦 目录 题意:传送门  原题目描述在最下面.  一个nm的矩阵,有坑有草,可以用1x长度的木板盖住坑,但不能盖到草. ...

  10. 基于Netty的RPC架构学习笔记(三):netty客户端

    文章目录 举个