zoukankan      html  css  js  c++  java
  • Java中正则Matcher类的matches()、lookAt()和find()的区别

    在Matcher类中有matches、lookingAt和find都是匹配目标的方法,但容易混淆,整理它们的区别如下:

    • matches:整个匹配,只有整个字符序列完全匹配成功,才返回True,否则返回False。但如果前部分匹配成功,将移动下次匹配的位置。
    • lookingAt:部分匹配,总是从第一个字符进行匹配,匹配成功了不再继续匹配,匹配失败了,也不继续匹配。
    • find:部分匹配,从当前位置开始匹配,找到一个匹配的子串,将移动下次匹配的位置。
    • reset:给当前的Matcher对象配上个新的目标,目标是就该方法的参数;如果不给参数,reset会把Matcher设到当前字符串的开始处。

    使用示例代码来展示他们的区别更清晰明了:

    1. package net.oseye;
    2.  
    3. import java.util.regex.Matcher;
    4. import java.util.regex.Pattern;
    5.  
    6. public class IOTest {
    7. public static void main(String[] args){
    8. Pattern pattern = Pattern.compile("\d{3,5}");
    9. String charSequence = "123-34345-234-00";
    10. Matcher matcher = pattern.matcher(charSequence);
    11.  
    12. //虽然匹配失败,但由于charSequence里面的"123"和pattern是匹配的,所以下次的匹配从位置4开始
    13. print(matcher.matches());
    14. //测试匹配位置
    15. matcher.find();
    16. print(matcher.start());
    17.  
    18. //使用reset方法重置匹配位置
    19. matcher.reset();
    20.  
    21. //第一次find匹配以及匹配的目标和匹配的起始位置
    22. print(matcher.find());
    23. print(matcher.group()+" - "+matcher.start());
    24. //第二次find匹配以及匹配的目标和匹配的起始位置
    25. print(matcher.find());
    26. print(matcher.group()+" - "+matcher.start());
    27.  
    28. //第一次lookingAt匹配以及匹配的目标和匹配的起始位置
    29. print(matcher.lookingAt());
    30. print(matcher.group()+" - "+matcher.start());
    31.  
    32. //第二次lookingAt匹配以及匹配的目标和匹配的起始位置
    33. print(matcher.lookingAt());
    34. print(matcher.group()+" - "+matcher.start());
    35. }
    36. public static void print(Object o){
    37. System.out.println(o);
    38. }
    39. }

    输出结果:

      1. false
      2. 4
      3. true
      4. 123 - 0
      5. true
      6. 34345 - 4
      7. true
      8. 123 - 0
      9. true
      10. 123 - 0
  • 相关阅读:
    JAVA实现AES的加密和解密算法
    工厂方法模式(Factory Method)
    Java开发23种设计模式
    读取Maven项目下resources目录下的配置文件(properties为例)
    迭代解析JSON简单实例
    Tomcat8.0配置JNDI多数据源
    SpringMVC DispatcherServlet-------视图渲染过程
    【C/C++】求解线性方程组的雅克比迭代与高斯赛德尔迭代
    【C/C++】实现牛顿迭代
    【C/C++】查找(一):静态查找表
  • 原文地址:https://www.cnblogs.com/ldq2016/p/6183572.html
Copyright © 2011-2022 走看看