首先是用法:
appendReplacement是java中替换相应字符串的一个方法
appendReplacement(StringBuffer sb,String replacement)
将当前匹配子串替换为指定字符串,并且将替换后的子串以及其之前到上次匹配子串之后的字符串段添加到一个 StringBuffer 对象里
appendTail(StringBuffer sb)
将最后一次匹配工作后剩余的字符串添加到一个 StringBuffer 对象里
简单来说,就是appendReplacement方法,会将匹配到的内容替换成相关字符串,然后追加写入到StringBuffer中,下次再遇到匹配的内容的话,先追加拼接未匹配到的字符串,然后再追加替换的字符串。
然后通过appendTail来追加写入末尾的未匹配到的剩余的字符串到StringBuffer对象中。
这里我们结合一个案例分析:
这里我们会通过正则表达式匹配字符串中的cat子串,然后通过遍历发现的所有字符串,并通过appendReplacement替换所有cat字串,最后通过appendTail方法追加写入剩余的字符串。
public class TheReplacements {
public static void main(String[] args) throws Exception {
// 生成 Pattern 对象并且编译一个简单的正则表达式"cat"
Pattern p = Pattern.compile("cat");
// 用 Pattern 类的 matcher() 方法生成一个 Matcher 对象
Matcher m = p.matcher("fatcatfatcatfat");
StringBuffer sb = new StringBuffer();
while(m.find()){
//此时sb为fatdogfatdog,cat被替换为dog,并且将最后匹配到之前的子串都添加到sb对象中
m.appendReplacement(sb,"dog");
}
//此时sb为fatdogfatdogfat,将最后匹配到后面的子串添加到sb对象中
m.appendTail(sb);
//输出内容为fatdogfatdogfat
System.out.println("sb:"+sb);
}
}
最后,再提供一个实际开发过程中遇到的案例,如下图中所示:
左边的代码中,再匹配到替换内容后,又用String.replace方法再次比对了一次字符串进行替换,而右边则是通过matcher.appendReplacement来追加替换内容,其会根据匹配到的内容下标去追加写入,而不是重新全局匹配一次。相对于前者来说,在字符串长度较长的情况下,会有不小的性能提升