我有一个场景,我想设置一个Boolean
对象,然后在方法中稍后在构造函数中使用它的booleanValue()
。但是,设置对象的范围是不同的。它是在方法调用的方法中设置的,其中首先实例化对象。根据我对Java如何传递原始和对象参数以及在线阅读多个帖子(例如this)的理解,当一个对象传递给一个方法时,它的属性通过引用传递,并且被调用方法的任何更改都应该在被调用方法完成执行后反映在调用方法中。但是我注意到,当被调用的方法完成时,其中的任何更改都不会在调用方法中生效。
以下是我的方案的快照:
private CustomObject1 callingMethod(){
Boolean b = Boolean.TRUE;
List<CustomObject2> list = this.calledMethod(b);
//Create CustomObject1 with b.booleanValue() as one of the arguments in the constructor
}
private List<CustomObject2> calledMethod(Boolean b){
...
...
if(condition){
b = Boolean.FALSE;
}
...
...
}
到代码到达时,CustomObject
创建b.booleanValue()
始终为true,即使callingMethod()
中的if语句为true且Boolean
设置为false在那种方法中。
我不愿意将调用方法的返回类型更改为boolean
,因为它需要更改可能调用此方法的其他代码位。目前他们只需要签名更改但返回类型更改需要更多工作,因为需要维护逻辑(即填充列表然后使用它执行某些操作)
答案 0 :(得分:22)
首先,在Java中有很多关于参数传递的错误信息,例如&#34;对象通过引用传递,基元通过值传递#34;这是不正确。 一切按值传递。
您没有在Java中通过引用传递对象,而是按值传递对象引用。 Boolean b
不包含Boolean
对象,它包含Boolean
对象的引用(指针)。
这是一篇关于它的好文章:http://javadude.com/articles/passbyvalue.htm
其次,Boolean
(与其他包装器对象和String
一样)是不可变对象。因此,对于一个不可变对象,并且它们通过值传递(更好地说,它们的引用按值传递),您无法实现您想要的。你需要有一个可变对象,比如@rob提到的。
答案 1 :(得分:2)
问题是您在{calledMethod}中重新分配b
。在calledMethod中重新分配只重新分配在该方法的参数列表中声明的变量;它不会修改在调用者范围内声明的变量。
要执行您想要实现的目标,您可以将b
转换为字段,也可以创建一个MutableBoolean类,允许您执行类似b.setValue(false)
的操作。