use*_*060 8 java pass-by-reference pass-by-value
我有一个场景,我想设置一个Boolean对象,然后booleanValue()在方法中的构造函数中使用它.但是,设置对象的范围是不同的.它是在方法调用的方法中设置的,其中首先实例化对象.根据我对Java如何通过原始和对象参数和在线阅读的几个职位(如理解这个),当一个对象被传递给方法,它的属性是通过引用传递和调用方法的任何变化应在体现调用方法完成执行后调用方法.但是我注意到,当被调用的方法完成时,其中的任何更改都不会在调用方法中生效.
这是我的场景的快照:
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;
}
...
...
}
Run Code Online (Sandbox Code Playgroud)
到代码到达时,CustomObject创建b.booleanValue()始终为true,即使if语句callingMethod()为true且Boolean在该方法中设置为false.
我不愿意将调用方法的返回类型更改为,boolean因为它需要更改可能调用此方法的其他代码位.目前他们只需要签名更改但返回类型更改需要更多工作,因为需要维护逻辑(即填充列表然后使用它执行某些操作)
eri*_*cbn 25
首先,在Java中有很多关于参数传递的错误信息,比如"通过引用传递对象,通过值传递基元",这是不正确的.一切都是通过价值传递的.
您没有在Java中通过引用传递对象,而是按值传递对象引用.Boolean b它不包含Boolean对象,它包含对象的引用(指针)Boolean.
这是一篇很好的文章:http://javadude.com/articles/passbyvalue.htm
其次,Boolean(与其他包装器对象一样String)也是不可变对象.因此,对于一个不可变对象,并且它们通过值传递(更好地说,它们的引用按值传递),您无法实现您想要的.你需要有一个可变对象,比如提到的@rob.
或者MutableBoolean从Apache Commons Lang使用.
问题是您正在b调用的方法中重新分配。在 calledMethod 中重新分配只会重新分配在该方法的参数列表中声明的变量;它不会修改在调用者作用域中声明的变量。
要完成您想要实现的目标,您可以转换b为一个字段,或者创建一个 MutableBoolean 类,它允许您执行类似b.setValue(false).