引用类型数据作为参数
看这样一个例子:
public class TestReferenceData {
public static void main(String[] args) {
String a = "aaa";
System.out.println(a);
change(a);
System.out.println(a);
}
private static void change(String b) {
b = "bbb";
}
}
你觉得打印结果会是什么呢?可能你会认为打印结果是这样的:
aaa
bbb
然而打印结果是这样的:
aaa
aaa
有没有感到很惊讶?我在碰到这个问题时也是楞了一下,仔细思考一番后才知道问题出在哪里。
要想弄清这个问题,首先要明确一个概念:Java语言中数据分有两类——基本类型和引用类型。
- 基本类型数据指的是值(数值、布尔值或者字符)
- 引用类型数据指的是地址值(对象在内存空间中的地址值)
在弄清楚上面两点之后,接下来就好理解了。
很明显,例子中的String类型变量a存放的是一个地址值(内存空间中字符串“aaa”的地址值),假设该地址值是15db9742。接着我们打印变量a,这里实际的操作是根据变量a记录的地址值去内存空间中找到对应的对象(这里是字符串“aaa”),然后将该对象打印出来。
然后我们调用change()方法。该方法接受一个String类型参数,change(a)语句执行时,change()方法的参数——String类型变量b,就会被赋予变量a存放的地址值。也就是说,变量b存放的地址值是变量a存放的地址值的拷贝。此时,变量b记录的地址值也是15db9742。
接下来变量b被赋值字符串“bbb”。此时变量b存放的地址值发生了变化,该值被内存空间中字符串“bbb”的地址值——假设该地址值是6d06d69c——所覆盖,变量b存放的地址值变成了6d06d69c。
change()方法调用结束后,变量b被释放,我们对变量b所进行的一系列操作对均没有对变量a造成任何影响。因此再次打印变量a的结果依然是“aaa”。
具体可以参考下图:
综上所述,引用类型数据作为参数传递时,方法参数接收到的是地址值的拷贝,通过方法调用无法改变原引用的指向。
虽然我们无法通过方法调用改变引用类型变量存放的地址值,但是我们可以通过方法调用来改变引用指向的内存空间中的对象。具体看下面一个例子:
public class TestChangeReferenceData {
public static void main(String[] args) {
int[] arr = new int[2];
arr[0] = 1;
print(arr);
change(arr);
System.out.println("==============");
print(arr);
}
private static void change(int[] a) {
a[1] = 2;
}
private static void print(int[] a) {
for (int i = 0; i < a.length; i++)
System.out.println(a[i]);
}
}
打印结果如下:
1
0
==============
1
2
change()方法中给数组a的第二个元素赋值2时,实际的操作这样的进行的:首先根据变量a存放的地址值(假设该地址值是15db9742),在内存空间中找到相应的对象(这里的对象是一个数组),然后对该对象进行操作。此时,change()方法中的变量a和main()方法中的变量arr记录的是同一个地址值,换而言之,引用a和引用arr指向同一个对象。因此在change()方法调用结束后,引用arr所指向的对象已经被修改了。
具体可以参考下图:
基本类型数据作为参数
同样的我们来看一个例子:
public class TestPrimitiveData {
public static void main(String[] args) {
int a = 2;
System.out.println(a);
change(a);
System.out.println(a);
}
private static void change(int b) {
b = 5;
}
}
打印结果如下:
2
2
如果之前所说的你已经明白了,那么这个例子应该完全难不住你了。
变量a是基本数据类型,所以int类型变量a存放的就是一个单纯的数值2。在调用change(a)时,change方法的参数——int类型变量b——被赋值2。然后我们给变量b赋值5,自然是无法影响到变量a的。
具体可以参考下图:
总结
1、在Java中引用类型数据和基本类型数据作为参数传递时都是值传递。
2、在方法调用中无法修改传入变量的值。