正则表达式find()方法的问题。

Matcher类find()方法 的说明:返回目标字符串是否包含和正则表达式匹配的子串。
后来用了while(m.find())
{
System.out.println(m.group());
}
假设目标字符串aaaaaab,正则表达式a*b,“aaaaaab”里无疑包含和“a*b”匹配的子串。那么,while括号里的将永远成立。岂不是无限循环?

文档里很清楚:
find
public boolean find()尝试查找与该模式匹配的输入序列的下一个子序列。

此方法从匹配器区域的开头开始,如果该方法的前一次调用成功了并且从那时开始匹配器没有被重置,则从以前匹配操作没有匹配的第一个字符开始。

如果匹配成功,则可以通过 start、end 和 group 方法获取更多信息。

matcher.start() 返回匹配到的子字符串在字符串中的索引位置.
matcher.end()返回匹配到的子字符串的最后一个字符在字符串中的索引位置.
matcher.group()返回匹配到的子字符串
返回:
当且仅当输入序列的子序列匹配此匹配器的模式时才返回 true。

好奇怪,没明白问题点在哪儿,你用while循环,里面还是个true条件,m初始化之后还不重新赋值,那当然是无限循环了。。。

不会无限循环啊,就跟你IO的randomaccessfile读写一样,匹配后游标是往后移动的,一直到最后匹配不到就退出了

那是你自己代码的逻辑问题,和正则表达式有什么关系?

文档里很清楚:
find
public boolean find()尝试查找与该模式匹配的输入序列的下一个子序列。

此方法从匹配器区域的开头开始,如果该方法的前一次调用成功了并且从那时开始匹配器没有被重置,则从以前匹配操作没有匹配的第一个字符开始。

如果匹配成功,则可以通过 start、end 和 group 方法获取更多信息。

matcher.start() 返回匹配到的子字符串在字符串中的索引位置.
matcher.end()返回匹配到的子字符串的最后一个字符在字符串中的索引位置.
matcher.group()返回匹配到的子字符串
返回:
当且仅当输入序列的子序列匹配此匹配器的模式时才返回 true。

public class Test {
public static void main(String[] args)
{
Pattern p=Pattern.compile("a");
Matcher m=p.matcher("aaa");
int count=0;
while(m.find())
{
count++;
}
System.out.println(count);
}
}
这个程序的结果是3
说明了当mc.find()运行一次之后,与字符串第一个字符配上了再次调用时,会接着比较第二个字符,当配上了就会返回TRUE,没有的话就返回FALSE