这段代码的目的是将htmlString 中所有start开始到end结束的地方,都用newString替换。主要使用String的indexOf方法和subString方法来定位,通过while来做循环,当indexOf方法的返回值为-1,即找不到start或者end时,循环终止。使用StringBuffer、以及它的构造方法和append方法还有toString来构建新的字符串。
private static String replaceAll(String htmlString,
String start,
String end,
String newString,
boolean logError,
boolean reportError)
{
StringBuffer modString = new StringBuffer(htmlString.length());
int i = 0, j = 0, j2=0;
int tagFound = 0;
while(true) {
// first check if there are any matching start & end
i = htmlString.indexOf(start, j2);
if( i != -1 ) {
j = htmlString.indexOf(end, i);
} else {
j = htmlString.indexOf(end, j2);
}
if ((i != -1) && (j != -1)) {
tagFound++;
modString.append( htmlString.substring(j2, i)).append( newString );
j2 = j + end.length();// 此处不可以改为
// j2 = modString.length();因为进行查找相同的操作时是在htmlString上// 操作的,htmlString是没有变过的。进行拼接操作的是modString.
}
else {
modString.append( htmlString.substring(j2));
if((i != -1) && (j == -1) || (i == -1) && (j != -1)) {
//hack, to report same error message as if no tags found at all.
//if later determined to report a different error message if we do
//find tags but the last tag is not matched, we just need
//to put the logic here.
tagFound = 0;
}
break;
}
}
if( tagFound == 0 ) {
if (logError) {
// write the stack trace to the log file
String msg = "No matching tag for " + start + " or " + end;
EfsnNonFatalException e = new EfsnNonFatalException(msg);
LogWriter.log(e);
}
if (reportError) {
return "no matching tag found in replaceAll=" + start;
}
else {
return htmlString;
}
}
return modString.toString();
}
上面代码中用到的indexOf方法,如
strObj.indextOf(subString, startIndex);
其返回值为字符串subString在strObj中从startIndex之后出现的第一个位置。如果参数startIndex是负数,则被当做0处理。当返回结果为-1时,表示没有找到。
上面代码中用到的subString方法,如
str=str.substring(beginIndex);
表示截取掉str从首字母起长度为beginIndex的字符串,将剩余字符串赋值给str;
str=str.substring(beginIndex,endIndex);
表示截取str中从beginIndex开始至endIndex结束时的字符串,并将其赋值给str;