public String replace(char oldChar, char newChar) {
if (oldChar != newChar) { //首先判断了两个字符是否一致
int len = value.length;
int i = -1;
char[] val = value;
while (++i < len) { 在长度范围内检测,同时变量增加
if (val[i] == oldChar) {//如果出现我们想要改变的变量则在当前索引停止,进行操作
break;
}
}
if (i < len) {//判断长度依然在范围内
char buf[] = new char[len];拿到一个与原数组相同的数组
for (int j = 0; j < i; j++) { //循环将不需要改变的字符添加到新数组
buf[j] = val[j];
}
while (i < len) {
char c = val[i]; //拿到需要变更的字符
buf[i] = (c == oldChar) ? newChar : c;//再次确认是否需要改变
i++;
}
return new String(buf, true);
}
}
return this;
String类的前三步操作对整个操作流程进行了筛选提高了效率。这里只讨论了replace(char old,char new)方法,replaceAll的实现方式并不相同,是调用了pattern类中的方法完成,其中还调用了matcher匹配器类参与。