我是靠谱客的博主 寒冷早晨,最近开发中收集的这篇文章主要介绍正则表达式 .*(贪婪匹配),.*?(惰性匹配),觉得挺不错的,现在分享给大家,希望可以做个参考。

概述

+或*后跟?表示惰性匹配,即尽可能少的匹配,如*?重复任意次,但尽可能少重复;

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

public class JavaTest {

    public static void main(String[] args) {
        String str = "<H1>Chapter 1 - 介绍正则表达式</H1>";
        Pattern pattern = Pattern.compile("<.*?>");
        Pattern pattern2 = Pattern.compile("<.*>");
        Matcher matcher = pattern.matcher(str);
        Matcher matcher2 = pattern2.matcher(str);

        System.out.println("------.*?------");
        while (matcher.find()) {
            String res = matcher.group();
            System.out.println(matcher.start() + "-" + res + "-" + matcher.end());
        }

        System.out.println("------.*------");
        while (matcher2.find()) {
            String res = matcher2.group();
            System.out.println(matcher2.start() + "-" + res + "-" + matcher2.end());
        }
    }

}

输出
------.?------
0-<H1>-4
23-</H1>-28
------.
------
0-<H1>Chapter 1 - 介绍正则表达式</H1>-28

最后

以上就是寒冷早晨为你收集整理的正则表达式 .*(贪婪匹配),.*?(惰性匹配)的全部内容,希望文章能够帮你解决正则表达式 .*(贪婪匹配),.*?(惰性匹配)所遇到的程序开发问题。

如果觉得靠谱客网站的内容还不错,欢迎将靠谱客网站推荐给程序员好友。

本图文内容来源于网友提供,作为学习参考使用,或来自网络收集整理,版权属于原作者所有。
点赞(62)

评论列表共有 0 条评论

立即
投稿
返回
顶部