Java面试题

题目一: float a = 0.125f; double b = 0.125d; System.out.println((a - b) == 0.0); 代码的输出结果是什么?
A. true √
B. false

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

题目二: double c = 0.8; double d = 0.7; double e = 0.6; 那么c-d与d-e是否相等?
A. true
B. false √

类似十进制里面的分数1/3,就是无限循环数,无法精确表示出来,同理浮点数里有些数值也没法精确表示出来。

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

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

题目四: System.out.println(0.0 / 0.0); 的结果是什么?
A. 抛出异常
B. Infinity
C. NaN √
D. 1.0

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

题目五: >>和>>>的区别是?
A. 任何整数没有区别
B. 负整数一定没有区别
C. 浮点数可以>>运算,但是不可以>>>运算
D. 正整数一定没有区别 √

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

题目六: 某个类有两个重载方法:void f(String s) 和 void f(Integer i),那么f(null)的会调用哪个方法?
A. 前者
B. 后者
C. 随机调用
D. 编译出错 √

JVM在重载方法中,选择合适的目标方法的顺序如下:

(1)精确匹配;
(2)如果是基本数据类型,自动转换成更大表示范围的基本类型;
(3)通过自动拆箱与装箱;
(4)通过子类向上转型继承路线依次匹配;
(5)通过可变参数匹配。

子类向上转型,两者的父类都是object类(null默认类型是object),因而会同时匹配上两者,编译器会报Ambiguous method call. Both错误

题目七: 某个类有两个重载方法:void g(double d) 和 void g(Integer i),那么g(1)的会调用哪个方法?
A. 前者 √
B. 后者
C. 随机调用
D. 编译出错

JVM在重载方法中,选择合适的目标方法的顺序如下:

(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。

题目十: 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,因而不需要扩容。

/**
     * Returns a power of two size for the given target capacity.
     */
    static final int tableSizeFor(int cap) {
        int n = cap - 1;
        n |= n >>> 1;
        n |= n >>> 2;
        n |= n >>> 4;
        n |= n >>> 8;
        n |= n >>> 16;
        return (n < 0) ? 1 : (n >= MAXIMUM_CAPACITY) ? MAXIMUM_CAPACITY : n + 1;
    }

参考
这份Java面试题,阿里P7的正确率都不到50%!!

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值