Java:条件运算符与if/else不同

Bri*_*ian 3 java if-statement operator-keyword

为什么条件运算符返回2.0并且if/else块在以下示例中返回2?我有点困惑,因为这两个块应该相等:

如果别的:

double value = 2.0;
Object result;

if (value == Math.floor(value)) {
    result = ((int) value);
} else {
    result = value;
}
Run Code Online (Sandbox Code Playgroud)

有条件的操作员:

double value = 2.0;
Object result;
result = value == Math.floor(value) ? ((int) value) : value;
Run Code Online (Sandbox Code Playgroud)

但是,命令

System.out.println(result);
Run Code Online (Sandbox Code Playgroud)

打印2.0或2

谢谢你的帮助!

Jon*_*eet 11

两种情况都采用相同的分支.您可以通过对不同分支使用非常不同的答案来验证:

if (value == Math.floor(value)) {
    result = ((int) value * 100);
} else {
    result = value;
}
Run Code Online (Sandbox Code Playgroud)

result = value == Math.floor(value) ? ((int) value * 100) : value;
Run Code Online (Sandbox Code Playgroud)

在这两种情况下,您将获得200或200.0.

另一个验证方法是通过使条件不变来删除条件:

boolean condition = true;
if (condition) { 
    ...
}
Run Code Online (Sandbox Code Playgroud)

result = condition ? ...;
Run Code Online (Sandbox Code Playgroud)

但是,不同之处在于,对于条件运算符,条件表达式double的类型是- 第二个操作数的类型是int(由于强制转换),第三个操作数的类型是double.条件运算符只能有一个类型,因此它遵循JLS和picks中的规则double(int可隐式转换为double但不反之亦然).也就是说double然后装箱作为分配到的部分result(这是类型的Object).因此,result最终成为对a的引用的值Double,并打印为2.0.

使用第一种方法,结果是一个Integer,因为你int直接分配给result它,它只是被自动装箱.

您可以通过将操作数强制转换为使条件运算符的行为方式相同Object.例如:

result = value == Math.floor(value) ? ((int) value) : (Object) value;
Run Code Online (Sandbox Code Playgroud)

现在有条件的经营者本身的类型Object,则int是盒装,以Integer作为评估条件运算符的一部分.