package com.atguigu.String01;
public class String01 {
public static void main(String[] args) {
// 字符串不变性
String str = "hello";// 对象成员数组是final
change(str);
System.out.println("change后的str:"+str);
int[] a = {1,3,5,7,9};
int[] b = {2,3,4,5,6};
System.out.println("a = " + a);
System.out.println("b = " + b);
change(a);
System.out.println("a = " + a);
for (int i = 0; i < 3; i++){
System.out.println(a[i]);
}
}
public static void change(String str){
str = str + "abc";
// str的地址是final String 拼接都是创建新串
System.out.println("方法中的str:"+str);
}
// 不能修改指针指向的地址 只能修改指针指向中的内容
public static void change(int[] a){
a = null;
}
}
方法是想让数组变成另一个数组,字符串变成另一个字符串,
但是从结果看,显然失败了.
那么,原因是什么呢?
我们已知数组中的变量在方法中是可以更改的,但是数组不可改,为什么?我认为,是因为传入的参数,是地址,或者我称之为指针更合适,
用字符串来说.
假设实参是str1 他传入时,会重新创建一个字符串(形参)来接收这个字符串的地址,这时,2个并不是一个变量,而是指针相同的两个变量
这时刚开始的那个图,str自己创建一个String对象.
当方法进栈运行时,会先创建一个String对象,也就是我们说的形参,或者说String对象
但是,我们要知道,这里没有初始化,指的是同一片地址,指针是相同的,或者说,对象是相同的
也就是说
String formalParameter = String对象1的地址
String str = String对象1的地址
但是,问题来了,当我们修改字符串的值,也就是下面这个语句时,
formalParameter = formalParameter + "abc";
会重新创建一个字符串,这时就变成了这样,这里就和原来的字符串没有关系了