关于String.replace方法的源代码中的“==”使用的疑惑(常量池与堆的问题)
public String replace(char oldChar, char newChar) {
if (oldChar != newChar) {
int len = value.length;
int i = -1;
char[] val = value; /* avoid getfield opcode */
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;
}
```java
String str = new String("abcabc") ;
System.out.println(str.replace('b','w'));//这里为什么可以replace成功
###### 产生疑问的原因
在String str = new String("abcabc") ;中,常量池产生对象"abcabc",str指向堆中产生的对象"abcabc"。
然后,对str调用replace方法,传入'b'和'w',那'b'和'w'应该是常量池中的对象。
然后到源码中,char[] val=value;我的理解就是现在val指向的是str所指向的堆中的"abcabc",
然后我觉得val[i]也是指向堆中的,那为什么char c = val[i];之后,可以使用==判断c和oldchar相不相等?
oldchar作为形参,接收的'b',地址应该是在常量池中。所以为什么可以使用'=='
java但凡涉及到方法的执行,不会在堆中执行,是在帧栈里面执行。虽然你看着参数是在常量池里面,但是在执行方法的时候会将此值复制一份到帧栈中占用一个槽位,char c = val[i] 执行这个,实际上是一个槽位向另为一个槽位赋值。
== 就是比较基本数据类型的,那你得两个char(基本数据类型之一),就得用==比较
你看的源码的参数类型是char,char是基本类型呀,不是String,不是引用类型,可以直接用==,比较ACSII码