String.replace中'=='使用疑惑-常量池与堆

问题遇到的现象和发生背景

关于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码