1.关于变量的赋值
- 如果变量是基本数据类型,此时赋值的是变量所保存的“数据值”。
- 如果变量是引用数据类型,此时赋值的是变量所保存的数据的“地址值”。
public class ValueTransferTest {
public static void main(String[] args) {
System.out.println("************基本数据类型***************");
int m = 10;
int n = m;
System.out.println("m = " + m + ",n = " + n);
n = 20;
System.out.println("m = " + m + ",n = " + n);
System.out.println("*************引用数据类型*************");
Order o1 = new Order();
o1.orderId = 1001;
Order o2 = o1;//赋值以后,o1和o2的地址值相同,都指向了堆空间中同一个对象实体
System.out.println("o1.orderId = " + o1.orderId + ",o2.orderId = " + o2.orderId);
o2.orderId = 1002;
System.out.println("o1.orderId = " + o1.orderId + ",o2.orderId = " + o2.orderId);
}
}
class Order{
int orderId;
}
运行结果如下:
在引用数据类型中,o1对象把自己的地址值传递给o2,此时修改数据的话,o1和o2都会改变。
2.方法形参的传递机制:值传递
在介绍值传递之前,大家需要了解一下形参和实参的概念:
- 形参:方法定义时,声明在小括号内的参数
- 实参:方法调用时,实际传递给形参的数据
值传递机制:
- 如果参数是基本数据类型,此时实参赋给形参的是实参真是存储的数据值。
- 如果参数是引用数据类型,此时实参赋给形参的是实参存储数据的地址值。
基本数据类型介绍代码如下:
public class ValueTransferTest1 {
public static void main(String[] args) {
int m = 10;
int n = 20;
System.out.println("m = " + m + ", n = " + n);
//交换两个变量的值
// int temp = m;
// m = n;
// n = temp;
ValueTransferTest1 test1 = new ValueTransferTest1();
test1.swap(m, n);
System.out.println("m = " + m + ", n = " + n);
}
public void swap(int m, int n) {
int temp = m;
m = n;
n = temp;
}
}
运行结果如下图:
很显然最后调用方法之后,并没有实现main方法中m和n的值交换,为什么呢?那么下面用内存解析来解释:
从图中我们可以看出在main()中调用swap()方法,传递的只是m和n所对应的值,当swap方法运行结束之后,里面所定义的值会被释放,所以并没有达到交换的目的。
引用数据类型介绍代码如下:
public class ValueTransferTest2 {
public static void main(String[] args) {
Data data = new Data();
data.m = 10;
data.n = 20;
System.out.println("m = " + data.m + ",n = " + data.n);
//交换m和n的值
// int temp = data.m;
// data.m = data.n;
// data.n = temp;
ValueTransferTest2 test2 = new ValueTransferTest2();
test2.swap(data);
System.out.println("m = " + data.m + ",n = " + data.n);
}
public void swap(Data data) {
int temp = data.m;
data.m = data.n;
data.n = temp;
}
}
class Data{
int m;
int n;
}
运行结果如下图:
很显然最后调用方法之后,实现了参数值的交换,同样使用内存解析来解释:
从图中可以显然看出,方法形参中data的变量和调用方法所传入的实参的变量是引用数据类型,也就是说实参所传给形参的是地址不是一个对象,当swap()方法调用结束后,形参和方法中定义的temp都会释放,但是因为在main方法中创建的daa对象指向了m和n,所以m和n的值不会释放,以此达到了数据交换的目的。