30
2020
04

HashMap初始容量10000即new HashMap(10000),当往里put 10000个元素时,需要resize几次(初始化的那次不算)?

0次解释:比10000大,且最接近的2的n次方数是16384,默认负载因子是0.75,16384*0.75 = 12288>10000,因而不需要扩容。
30
2020
04

String get(String string, T t) { return string; } 此方法:

编译正确解释:尖括号里的每个元素都指代一种未知类型,在定义处只具备执行Object方法的能力,在编译期间,所有的泛型信息都会被擦除,编译后,get()的两个参数是Object,返回值也是Object。
30
2020
04

String a = null; switch(a)匹配case中的哪一项?

直接抛出异常解释:在Java编程语言的设计者的判断中,这比静默跳过整个开关语句要合理,因为使用null作为开关标签的话,编写的代码将永远不会执行。
30
2020
04

某个类有两个重载方法:void g(double d) 和 void g(Integer i),那么g(1)的会调用哪个方法?

前者解释:1)精确匹配->2)基本数据类型(自动转换成更大范围)->3)封装类(自动拆箱与装箱)->4)子类向上转型依次匹配->5)可变参数匹配,本题是进行到第二步匹配上了。
30
2020
04

某个类有两个重载方法:void f(String s) 和 void f(Integer i),那么f(null)的会调用哪个方法?

 编译出错解释:1)精确匹配->2)基本数据类型(自动转换成更大范围)->3)封装类(自动拆箱与装箱)->4)子类向上转型依次匹配->5)可变参数匹配。子类向上转型,两者的父类都是object类(null默认类型是object),因而会同时匹配上两者,编译器会报Ambiguous method call. Both错误
30
2020
04

>>和>>>的区别是?

正整数一定没有区别解释:>>>表示不带符号向右移动二进制数,移动后前面统统补0;两个箭头表示带符号移动,正整数的符号位是0,因而两者没有区别
30
2020
04

System.out.println(0.0 / 0.0); 的结果是什么?

NaN解释:java源码,Double包装类下,public static final double NaN = 0.0d / 0.0;NAN表示非数字,它与任何值都不相等,甚至不等于它自己。
30
2020
04

System.out.println(1.0 / 0); 的结果是什么?

Infinity解释:在整型运算中,除数是不能为0的,否则直接运行异常。但是在浮点数运算中,引入了无限这个概念。可以看一下源码Double的定义, public static final double POSITIVE_INFINITY = 1.0 / 0.0;
30
2020
04

double c = 0.8; double d = 0.7; double e = 0.6; 那么c-d与d-e是否相等?

false解释:类似十进制里面的分数1/3,就是无限循环数,无法精确表示出来,同理浮点数里有些数值也没法精确表示出来。System.out.println(0.8-0.7);//输出0.10000000000000009System.out.println(0.7-0.6);//输出0.09999999999999998
30
2020
04

float a = 0.125f; double b = 0.125d; System.out.println((a - b) == 0.0); 代码的输出结果是什么?

true解释:首先浮点数是由符号位、指数位、有效数字三个部分组成,而0.125f、0.125d均可以精确的表示出来,不存在精度丢失,因而a-b==0.0。