以下代码输出结果是:
public class Test {
public static void main(String[] args) {
int a = 5;
System.out.println("value is " + ((a < 5) ? 10.9 :9));
}
}
A.编译错误 B. 10.9 C. 9 D. 以上答案都不对
解析:Java会根据运算符的精度类型进行自动类型的转换。由于前面有一个10.9,因此,后面的9会自动变成9.0。
答案:D
以下代码的输出结果是:
import java.util.*;
public class Test {
public static void main(String[] args) {
char x = 'x';
int i = 10;
System.out.println(false ? i : x);
System.out.println(false ? 10 : x);
}
}
A.120 x B. 120 120 C. x 120 D. 以上答案都不对
解析:inti=10;中的i是一个变量,因此,第一个输出x被提升为int型了,因为i是int型,x的int型值为120。当后两个表达式有一个是常量表达式时,另外一个类型是T时,而常量可以被T表示时,输出结果是T类型
答案:A
下列程序输出结果是:
import java.util.*;
public class Test {
public static void main(String[] args) {
int num = 32;
System.out.println(num >> 32);
}
}
A. 32 B. 16 C. 1 D. 0
解析:各位操作符右边的参数要先进行模的32运算,并且移位是对二进制的操作,而二进制中8位是一个循环。所以num>>32等于num>>0,而num>>33等于num>>1。
答案:A