java能传地址吗,关于java中是地址传送还是值传递的测试

本文探讨了Java中参数传递的基本原理,通过实例展示了基本数据类型和对象引用类型的传递区别。对于基本数据类型,Java实行值传递,而对象则是传递引用的副本。尽管在修改封装类对象时看起来像是值传递,但实际上是由于final类的不可变性导致的。最终结论是,Java中对象参数传递的是引用副本,基本数据类型传递的是值。
摘要由CSDN通过智能技术生成

关于java中是地址传递还是值传递的测试

首先,我的结论是,如果是对对象进行 操作的话,传的是地址,如果是对基本数据类型进行操作的话,传的是值!

下面,我再用一个小的实例来测试我的结论:

class Person {

int age;

public void setAge(int age){

this.age = age;

}

public int getAge(){

return age;

}

}

public class Test{

public static void main(String[] args){

Person p = new Person();

p.setAge(1);

changeObj(p);

System.out.println(p.getAge());

int a = 1;

change(a);

System.out.println(a);

}

static void changeObj(Person p){

p.setAge(12);

}

static void change(int a){

a = 123;

}

}如果,我上面的结论是猜测是正确的话,输出的结果应该是

age=12

a=1

下面截图表示一下:

111745786.gif

因此,说明了我的结论是正确的。可是突然想到,如果是基本数据类型的包装类的话会是什么结果呢?下面我们进行一个小的测试来寻找一下结论

public class Test{

public static void main(String[] args){

Integer b = new Integer(90);

change(b);

System.out.println(b);

}

static void change(int a){

a = 123;

}

}如果是值传递的话,那么结果应该是90,如果是地址传递的话,那么结果应该是123,下面贴图说明问题:

111745787.gif

上面说明了传递的是值,而不是地址,但是有一点,程序里面,change()方法这的参数是int,而不是Integer,这会不会影响结果呢?那么我们就再写一个例子测试,看一下结果:

public class Test{

public static void main(String[] args){

Integer b = new Integer(90);

change(b);

System.out.println(b);

}

static void change(Integer a){

a = 123;

}

}

下面来看结果,还是贴图查看:

111745788.gif

可以看出,结果依然没有变化,由此我们可以得到结论:基本数据类型,包括其包装类,在进行参数传递的时候传的是值。

综上所述,我们可以得到结论:在java中进行参数传递的时候,基本数据类型,包括其封装类,进行的是值传递,而对于对象,传递的是引用。

以上是本人的一个测试与结论,如果大家发现有什么不正确的地方,欢迎批评指正。

3楼MaggieDorami昨天 18:13java中对任何引用类型(包括对象、数组、简单类型封装类的实例自然也是对象)的传参传递的都是引用的副本。n之所以封装类的传参看起来像值传递,是因为封装类都是final类。查看jdk的api可以知道String类,封装类(Integer、Char...)等都是final类。final类是不可变类。n在尝试对这种对象进行修改时,java只是新建了另一个对象,并将传过来的引用的副本指向这个新的对象。而原来函数中的对象和引用并没有发生任何改变。因此看起来像值传递而已。n另外一点,java中的传递的都是副本,值的副本、引用的副本,而不是其本身Re: henushang昨天 21:03回复MaggieDoramin我试了一下,把远对象打印和传参的打印室同一个地址,那副本又是什么意思呢?把原来的堆内的对象空间重新生成了一个?可是为什么两个地址是一样的呢?Re: MaggieDorami昨天 21:48回复henushangn差不多是这个样子。这几天在重温java,如果有什么地方说的不准确欢迎指出。Re: MaggieDorami昨天 22:34回复henushangnc++中的传参是将指向对象地址的指针传过去,而java中将指向这个对象的引用复制了一份(也就是副本了)传过去。n堆内的对象只有一个,而在堆栈里此时有了两个指向该对象的引用,一个是原来的引用,另一个是引用的副本。因此打印出的地址自然是同一个了。n由于副本与引用本身指向的都是一个对象,因此对于可变对象的传参,不管对引用本身还是对引用的副本进行操作,结果都是改变了它们指向的那个对象。结果看起来与c++的差不多,但是机制稍微不同。n这也是有些java书中会说java只有值传递的原因。因为java中不管是值的传递还是引用的传递,传递的都是它们的副本。只是引用的副本和引用指向的是同一个对象而已。Re: henushang3小时前回复MaggieDoramin好吧,明白了,绕来绕去又回到我的那个地方了2楼ruancaipu昨天 17:20受用了、、Re: henushang昨天 18:08回复ruancaipun自己测试的 ,有什么不对的请指正1楼ygyz03昨天 12:29这篇文章最精华的就是MaggleDorami的回复,楼主学习可要抓住重点哦,测试的时候用例太少,这样会以偏概全,得出错误的结论,如果你又多加了一个String作为参数的测试,估计又能引发你新一轮的思考,进而更加靠近正确的答案。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值