matches和find的用法

Matcher类有几个进行匹配的方法,一个是matches,一个是find,前者是将整个输入和表达式进行匹配,而后者只是查找匹配的部分,只要找到匹配的就返回。一个典型的应用就是分析SQL,我们写一个表达式先判断整个SQL是否匹配表达式,如果匹配的话就要进行分析,取出我们想要的部分,但是WHERE条件部分有很多条件,使用group只能取到最后一次匹配的部分(参考以前写的Java正则表达式的性能问题你写的正则表达式有多复杂? ),这个时候就要针对条件再写一个表达式,使用find查找所有的条件了,代码片断如下: public Query parse(String query)
{
Matcher matcher = pattern.matcher(query);
if (!matcher.matches())
{
return null;
}
else
{
Query result = null;
try
{
result = doParse(matcher);
}
catch (Exception e)
{
log.error("Parse finder sql error!",e);
}
result.setSql(query);
log.debug(result);
return result;
}
}

protected void parseFields(Query result, Matcher matcher, int startGroup, Map extraInfo)
{
String fields = matcher.group(startGroup);
Matcher fieldsMatcher = fieldsPattern.matcher(fields);
int start = 0;
while (fieldsMatcher.find(start))
{
Option option = parseField(fieldsMatcher, 1, extraInfo);
result.addOption(option);
start = fieldsMatcher.end();
}
}

[@more@]

来自 “ ITPUB博客 ” ,链接:http://blog.itpub.net/785011/viewspace-912063/,如需转载,请注明出处,否则将追究法律责任。

转载于:http://blog.itpub.net/785011/viewspace-912063/

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值