如题 我始终看不懂上面的是什么意思 求大牛解答
[code="java"] /**
* [ab}]表示匹配a或b或}
* [^ab}]表示不匹配a或b或}
* [ab}]*表示一个字符串由a或b或}组成 表示之前出现零次或多次 默认是贪婪模式(最长匹配)
* *? 表示非贪婪模式(最短匹配,即惰性模式)
* (a)(b) 括号是分组 第0个分组是整个匹配的字符串,第1个是a 第二个是2以此类推
*
*
*/
Pattern greedyPattern = Pattern.compile("([^}])");//贪婪
Pattern reluctantPattern = Pattern.compile("([^}]*?)");//非贪婪
String str1 = "abc";
String str2 = "abc}";
System.out.println(greedyPattern.matcher(str1).matches());//true
System.out.println(greedyPattern.matcher(str2).matches());//false 因为包含}
System.out.println(reluctantPattern.matcher(str1).matches());//true
System.out.println(reluctantPattern.matcher(str2).matches());//false
[/code]
([^}]*?) 详细解释:
1、()表示捕获组,可以通过如下语句捕获组:
while(mathcer.find()) {
System.out.println(greedyMathcer.group(1));
}
第0个分组是整个匹配的,第一个分组是第一个() 第二个分组是第二个()
2、[^}] 表示非}字符都是合法的
3、*表示0个或多个 [^}]* 表示只要字符串中没有}即可
4、*? 表示一种非贪婪算法(默认如.*是贪婪 即最长匹配),是最短匹配;
5、([^}]*?) 表示只要字符串中没有}即可,而且捕获组是最短匹配;
6、这里有一份 不错的入门文章 [url]http://blog.csdn.net/hiyu2218/article/details/3404591[/url]
7、建议看下《精通正则表达式》 上边对于贪婪 非贪婪 捕获组等概念讲的很详细
8、正则表达式是一个很强大的工具,工作中经常用到
结论来讲,就是匹配以非}开头的任意字符串。
具体来讲,应该用在比如取函数体的内容
[code="java"]
void Function {
var i = 0;
i++;
}
[/code]
比如上面的代码中第1,2,3行都可以匹配上。
通常第1行会用另个表达式匹配。
([^}]*?)
[^}] —— 不是以}开头的。
[^}]这个是匹配字符串内非}的字符串,[^}]*这个就等于字符串内非}的字符出现n次或者不出现
除了}其他都可以