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

正则表达式find()方法的问题。
- 写回答
- 好问题 0 提建议
- 关注问题
- 邀请回答
-
6条回答 默认 最新
- threenewbee 2018-07-03 14:43关注
文档里很清楚:
find
public boolean find()尝试查找与该模式匹配的输入序列的下一个
子序列。
此方法从匹配器区域的开头开始,如果该方法的前一次调用成功了并且从那时开始匹配器没有被重置,则从以前匹配操作没有匹配的第一个字符开始。
如果匹配成功,则可以通过 start、end 和 group 方法获取更多信息。matcher.start() 返回匹配到的子字符串在字符串中的索引位置.
matcher.end()返回匹配到的子字符串的最后一个字符在字符串中的索引位置.
matcher.group()返回匹配到的子字符串
返回:
当且仅当输入序列的子序列匹配此匹配器的模式时才返回 true。本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报