贪婪量词:
先看整个字符串是不是一个匹配。如果没有发现匹配,它去掉最后字符串中的最后一个字符,并再次尝试。如果还是没有发现匹配,那么再次去掉最后一个字符串,这个过程会一直重复直到发现一个匹配或者字符串不剩任何字符。简单量词都是贪婪量词。
惰性量词:
先看字符串中的第一个字母是不是一个匹配,如果单独着一个字符还不够,就读入下一个字符,组成两个字符的字符串。如果还没有发现匹配,惰性量词继续从字符串中添加字符直到发现一个匹配或者整个字符串都检查过也没有匹配。惰性量词和贪婪量词的工作方式恰好相反。
支配量词:
只尝试匹配整个字符串。如果整个字符串不能产生匹配,不做进一步尝试。
贪婪量词惰性量词支配量词 描述
-------------------------------------------------------------------------------------
? ?? ?+ 可以出现0次或1次,但至多出现1次
* *? *+ 可以出现任意次,也可以不出现
+ +? ++ 出现1次或多次,但至少出现1次
{n}{n}? {n}+一定出现n次
{n,m}{n,m}?{n,m}+至少出现n次,但至多不能超过m次
{n,}{n,}? {n,}+可以出现任意次,但至少出现n次c)abbbaabbbaaabbb12
匹配第一个找到的字符串
String str="Ster: checkpoint:1309416967000, date07 GMu: checkpoint:1310547687000, d1";
Matcher matcher=Pattern.compile("checkpoint:(.*?),").matcher(str);
if(matcher.find()){
System.out.println(matcher.group(1));