在csdn上看到这样一个题目:
运行结果是( )
A ddsadasa9 B ddsadasa9.0 C 编译出错 D 以上答案都不对
说句老实话,我不看下面的人的讨论,就认定了答案是ddsadasa9,A;
去eclipse运行了一下该程序,结果居然是:ddsadasa9.0;
网上给的答案是:
有个专门的名词叫双目数值类型提升(binary numeric promotion)
在双目数值类型提升的情况下,如果任意一个操作数是 float 类型,那另外一个会被转换成为 float 类型;
条件表达式的一些说明:
操作数其中一个是 byte 或 Byte 类型,而另一个是 short 或 Short 类型,那么这个表达式就是 short 类型;
操作数中的一个是类型 T (T 可以是 byte、short 或者是 char 类型),而另一个是 int 类型的常数,其可以用 T 类型来表示时,那么这个表达式就是 T 类型;
操作数中的一个是 Byte 类型,而另一个是 int 类型的常数,其可以用 byte 类型来表示,那么这个表达式就是 byte 类型;
操作数中的一个是 Short 类型,而另一个是 int 类型的常数,其可以用 short 类型来表示,那么这个表达式就是 short 类型;
操作数中的一个是 Character 类型,而另一个是 int 类型的常数,其可以用 char 类 型来表示,那么这个表达式就是 char 类型;
否则,双目数值提升(binary numeric promotion)会被用于操作数的类型中,条件表达式的类型是第二个和第三个操作数提升后的类型。注意:双目数值提升时进行拆箱转换和值集转换(value set conversion);
我本人对于上面所说的不是太理解,但大家应该还记得这样的一个例子:
答案是:6.0。向高一级转型。。