近日在阿里技术公众号上看到一篇java基础考核题,号称P7也只有50%全对,怀着好奇心试了一下,嗯,果然被打脸,java基础知识还是需要进一步提高。
Java基础知识考核题
1. 浮点型数据
题目一. float a = 0.125f; double b = 0.125d; System.out.println((a - b) == 0.0); 代码的输出结果是什么?
A. true
B. false
A. 解释:浮点数是由符号、尾数、基数和指数这四部分来表示的小数。
我们以小数点后4位进行转换为例
由上图可见0.125f、0.125d均可以精确的表示出来,不存在精度丢失,因而a-b==0.0。
但如果像十进制数0.1,转换成二进制后,会变成0.00011001100…(1100循环)这样的循环小数,存在精度问题,就会造成0.1-0.1 != 0.0
题目二: double c = 0.8; double d = 0.7; double e = 0.6; 那么c-d与d-e是否相等?
A. true
B. false
B. 解释:原因如上题所示
System.out.println(0.8-0.7);//输出0.10000000000000009
System.out.println(0.7-0.6);//输出0.09999999999999998
题目三: System.out.println(1.0 / 0); 的结果是什么
A. 抛出异常
B. Infinity
C. NaN
题目四: System.out.println(0.0 / 0.0); 的结果是什么?
A. 抛出异常
B. Infinity
C. NaN
D. 1.0
解释:3-B, 4-C
在整型运算中,除数是不能为0的,否则直接运行异常。但是在浮点数运算中,引入了无限与NaN的概念。
以Double源码为例,
public static final double NEGATIVE_INFINITY = -1.0 / 0.0;
public static final double POSITIVE_INFINITY = 1.0 / 0.0;
public static final double NaN = 0.0d / 0.0;
同时也应用注意:
-
Infinity乘以0,结果为NaN
System.out.println(Float.POSITIVE_INFINITY * 0); // NaN System.out.println(Float.NEGATIVE_INFINITY * 0); // NaN
-
Infinity除以0,结果还是Infinity
System.out.println((Float.POSITIVE_INFINITY / 0) == Float.POSITIVE_INFINITY); // output: true System.out.println((Float.NEGATIVE_INFINITY / 0) == Float.NEGATIVE_INFINITY); // output: true
-
Infinity乖0之外其它的运算,结果都是Infinit
System.out.println(Float.POSITIVE_INFINITY == (Float.POSITIVE_INFINITY + 1)); // output: true System.out.println(Float.POSITIVE_INFINITY == (Float.POSITIVE_INFINITY - 1)); // output: true System.out.println(Float.POSITIVE_INFINITY == (Float.POSITIVE_INFINITY * 1)); // output: true System.out.println(Float.POSITIVE_INFINITY == (Float.POSITIVE_INFINITY / 1)); // output: true
-
NaN表示非数字,与任何值都不相等,甚至不等于它自己,所以要判断一个数是否为NaN要用isNaN方法:
System.out.println(Float.NaN == Float.NaN); // output: false
System.out.println(Double.isNaN(Float.NaN)); // output: true
2.java类型转换
题目五: 某个有两个重载方法:void f(String s) 和 void f(Integer i),那么f(null)的会调用哪个方法?
A. 前者
B. 后者
C. 随机调用
D. 编译出错
题目六: 某个类有两个重载方法:void g(double d) 和 void g(Integer i),那么g(1)的会调用哪个方法?
A. 前者
B. 后者
C. 随机调用
D. 编译出错
解释:5-D, 6-A
方法调用参数匹配逻辑:
1)精确匹配
2)基本数据类型(自动转换成更大范围)
3)封装类(自动拆箱与装箱)
4)子类向上转型依次匹配
5)可变参数匹配。
题目五:子类向上转型,两者的父类都是object类(null默认类型是object),因而会同时匹配上两者,编译器会报Ambiguous method call. Both错误
题目六:第二步即可匹配完成
题目七: String a = null; switch(a)匹配case中的哪一项?
A. null
B. “null”
C. 不与任何东西匹配,但不抛出异常
D. 直接抛出异常
解释:在Java编程语言的设计者的判断中,这比静默跳过整个开关语句要合理,因为使用null作为开关标签的话,编写的代码将永远不会执行。
题目八: String get(String string, T t) { return string; } 此方法:
A. 编译错误,从左往右第一个String处
B. 编译错误,T处
C. 编译错误,Alibaba处
D. 编译正确
解释:尖括号里的每个元素都指代一种未知类型,在定义处只具备执行Object方法的能力,在编译期间,所有的泛型信息都会被擦除,编译后,get()的两个参数是Object,返回值也是Object。
3. 其它类型题目
题目九: >>和>>>的区别是?
A. 任何整数没有区别
B. 负整数一定没有区别
C. 浮点数可以>>运算,但是不可以>>>运算
D. 正整数一定没有区别
解释:D. >> 、>>>只适用于整型.
表示不带符号向右移动二进制数,移动后前面统统补0;两个箭头表示带符号移动,正整数的符号位是0,因而两者没有区别
题目十: HashMap 初始容量 10000 即 new HashMap(10000),当往里 put 10000 个元素时,需要 resize 几次(初始化的那次不算)?
A. 1次
B. 2次
C. 3次
D. 0次
解释:比10000大,且最接近的2的n次方数是16384,默认负载因子是0.75,16384*0.75 = 12288>10000,因而不需要扩容。