转载声明:文章来源https://blog.csdn.net/yjclsx/article/details/81224352
Java中只有传值调用(值传递),没有传址调用(址传递或者引用传递)。所以在java方法中改变参数的值是不会改变原变量的值的,但为什么改变引用变量的属性值却可以呢?请看下面的解答。
java中的数据类型
Java中数据类型分为两大类:基本类型和引用类型。相应的,变量也分这两种类型:基本类型和引用类型。
基本类型的变量保存原始值,即它代表的值就是数值本身;
而引用类型的变量保存的值是引用值,"引用值"指向内存空间的地址,代表了某个对象的引用,而不是对象本身,对象本身存放在这个引用值所表示的地址的位置。
基本类型包括:byte,short,int,long,char,float,double,Boolean,returnAddress。
引用类型包括:类、接口类型和数组。
java中只有值传递
在日常编码中,会经常看到如下现象:
1、对于基本类型参数,在方法体内对参数进行重新赋值,不会改变原有变量的值。
2、对于引用类型参数,在方法体内对参数进行重新赋予引用,不会改变原有变量所持有的引用。
3、方法体内对参数进行运算,不会改变原有变量的值。
4、对于引用类型参数,方法体内对参数所指向对象的属性进行操作,将改变原有变量所指向对象的属性值。
举个例子:
public class Main {
private static void getMiddleOne(boolean b, Boolean boo, Boolean[] arr){
b = true;
boo = new Boolean(true);
arr[0] = true;
}
//测试
public static void main(String[] args) {
boolean b = false;
Boolean boo = new Boolean(false);
Boolean[] arr = new Boolean[]{false};
getMiddleOne(b, boo, arr);
System.out.println(b);
System.out.println(boo.toString());
System.out.println(arr[0]);
/**
* output:
* false
* false
* true
*/
}
}
我们只要了解了下面两点就可以解答上面的现象了:
1、基本数据类型的值就是数值本身,所以示例中的b的值就是false;包装类因为会自动装箱拆箱,所以可以和基本类型一样处理,所以示例中boo的值就是false;数组是引用类型,所以arr的值就是指向该Boolean[]的引用。
2、java中只有值传递没有引用传递,所以传入getMiddleOne方法的三个参数分别是b的值拷贝, boo的值拷贝, arr的值拷贝。
通过上面两点就可以清楚了,getMiddleOne方法中执行的 b=true 和 boo = new Boolean(true) 都是把新值赋给了他们的拷贝,所以不改变原变量的值;同样,arr[0] = true 是把true复制给了arr的拷贝所指向的数组的第一个元素,arr的值和arr的拷贝的值都是该数组的引用,所以arr的拷贝所指向的数组和arr所指向的数组是同一个,所以改变arr的拷贝的数组的元素会同样影响到原变量arr。
总结
java中只有值传递,基本类型传递的是值的副本,引用类型传递的是引用的副本。
帖子还没人回复快来抢沙发