贪婪匹配:当正则表达式中包含能接受到重复的限定符时,通常的行为是匹配尽可能多的字符,这中匹配方式叫做贪婪匹
配。特征是一次性读入整个字符串经行匹配,每当不匹配就舍弃最右边一个字符,继续匹配,依次匹配和舍弃,直到匹配成功或
者把整个字符串舍弃为止,因此它是一种最大化数据返回,能多不会少。
@Test
/*
* "%.*?%" 非贪婪匹配
*/
public void test4() {
String regx = "%.*?%"; //非贪婪匹配
String str = "%sbdddbfzh%\n %vgvcyvu%\n %ugbh%\n";
System.out.println(str.replaceAll(regx, "aaa"));
}
@Test
/*
* 分组匹配
*/
public void test5() {
String regx = "(%)(.*?)(%)"; //非贪婪匹配
String str = "%sbdddbfzh% %vgvcyvu% %ugbh%";
System.out.println(str.replaceAll(regx, "$2")); //去掉两边%%
System.out.println(str.replaceAll(regx, "$1aaa$3")); // 中间替换 两边被保留 不变
System.out.println(str.replaceAll(regx, "$1"));
}