代码:
public class Test {
public static void main(String[] args) {
int a = 20;
method1(a);
System.out.println("int..." + a);
Person p = new Person("张三");
method2(p);
System.out.println("Person..." + p);
String str = "A";
method3(str);
System.out.println("String..." + str);
}
public static void method1(int a){
a = 10;
}
public static void method2(Person p){
p.setName("李四");
}
public static void method3(String str){
str = "B";
}
}
结果:
解释int类型没有被改变的原因
传参的时候传过去的是一个变量副本,方法内改变的是变量副本的值,而不是真正a的值,然后再根据就近原则,使用的就是 int a = 20
解释Person类型被改变的原因
虽然最后还是就近原则,使用main方法中的p,但是它只是引用的一个地址,真正的值以及被改变了。
解释String类型没有被改变的原因
首先要知道常量池中的字符串一旦被创建是无法被改变的。
最后还是因为就近原则,选用main方法中的str的值输出。
总结:基本数据类型作为方法参数,传递的是变量副本,形参改变,实际值不会改变,所以原样输出。引用型数据类型作为方法的形参传递,传递的是引用地址,形参改变,实际值也会跟着改变。最后一种就是字符串,虽然属于引用型数据类型,但是因为字符串常量池的原因,字符串一旦被创建就不可改变的概念,给这个形参字符串赋值就相当于又创建了一个新的字符串,与原来的字符串已经没有啥关系了,所以原来的字符串指向的还是字符串A,最终根据作用域输出的还是A。