我在org.apache.commons.lang3.BooleanUtils
(版本3.1)中使用commons-lang3
。
当我尝试编译下一行代码时
BooleanUtils.xor(true, true);
使用maven-compiler-plugin
(版本3.3),我收到编译失败消息:
[ERROR] Failed to execute goal org.apache.maven.plugins:maven-compiler-plugin:3.3:compile (default-compile) on project exchange: Compilation failure
[ERROR] MyClass.java:[33,34] reference to xor is ambiguous, both method xor(boolean...) in org.apache.commons.lang3.BooleanUtils and method xor(java.lang.Boolean...) in org.apache.commons.lang3.BooleanUtils match
我使用Java 1.7.0_55进行编译。
我该如何解决这个问题?
答案 0 :(得分:6)
问题发生的原因是方法的签名具有可变参数。调用方法时,有3个阶段,在此阶段中搜索所有适用的方法。在phase 3中搜索具有可变参数的方法,其中拳击和取消装箱也是允许的。
所以xor(boolean...)
和xor(Boolean...)
都适用于此,因为拳击被考虑在内。当多种方法适用时,仅调用最具体的方法。但在这种情况下,boolean
和Boolean
无法进行比较,因此没有更具体的方法,因此编译错误:两种方法都匹配。
解决方法是创建一个显式数组:
public static void main(String[] args) {
xor(new boolean[] { true, false }); // will call the primitive xor
xor(new Boolean[] { Boolean.TRUE, Boolean.FALSE }); // will call the non-primitive xor
}
private static Boolean xor(Boolean... booleans) {
System.out.println("Boolean...");
return Boolean.TRUE;
}
private static boolean xor(boolean... booleans) {
System.out.println("boolean...");
return true;
}
答案 1 :(得分:0)
有趣:一个角落案例,其中autoboxing直接阻挡你。
解决这个问题的最简单方法是编写
var x = 1234.56780123;
x.toFixed(2); // output: 1234.56
x.toFixed(3); // output: 1234.568
x.toFixed(4); // output: 1234.5680