java Integer中隐藏的细节魔鬼!来自面试官的三轮暴击!
1 第一波暴击!!!
程序员比较实在,一般会说:
那就先上代码
package com.example.demo; public class TestInteger {public static void main(String[] args) {Integer SmallThan127=15; Integer anotherSmallThan127=15;System.out.println(SmallThan127==anotherSmallThan127);System.out.println(SmallThan127.equals(anotherSmallThan127));Integer biggerThan127=365;Integer anotherBiggerThan127=365;System.out.println(anotherBiggerThan127==biggerThan127);System.out.println(anotherBiggerThan127.equals(biggerThan127));} }
不卖官司,直接给出输出结果
truetrue
false
true
错误的去面壁吧!!!!!!!!!!!!!!
2 第二波暴击!!!
有人会说:“这个我知道![-128,127]之间,指向已经存在的对象的引用;否则创建一个新的Integer对象”
证据呢?为什么要这样做?涉及到了什么知识点?Boolean,Byte,Short,Character,Long,Float,Double等有没有同样的情况?如果有的话,范围分别是多少?
2.1 证据很好拿,debug一下
其中:static final int low = -128;high=127(间接)
2.2 这样做的依据是什么?
源码算吗?
Integer SmallThan127=15;Integer biggerThan127=365;
通过调用包装器的 Integer.valueOf方法实现的
/*** Returns an {@code Integer} instance representing the specified* {@code int} value. If a new {@code Integer} instance is not* required, this method should generally be used in preference to* the constructor {@link #Integer(int)}, as this method is likely* to yield significantly better space and time performance by* caching frequently requested values.** This method will always cache values in the range -128 to 127,* inclusive, and may cache other values outside of this range.** @param i an {@code int} value.* @return an {@code Integer} instance representing {@code i}.* @since 1.5*/public static Integer valueOf(int i) {if (i >= IntegerCache.low && i <= IntegerCache.high)return IntegerCache.cache[i + (-IntegerCache.low)];return new Integer(i);}
这就是传说中的装箱boxing
还是不理解,不见棺材不落泪呀!
看实现标准,官方指定的,犹如宪法
关于装箱的转换【1】
2.3 Boolean,Byte,Short,Character,Long,Float,Double这些看spec就行,还要我说吗?
3 第三波暴击!!!
public class TestInteger {public static void main(String[] args) {Integer SmallThan127=new Integer(15); Integer anotherSmallThan127=new Integer(15);System.out.println(SmallThan127==anotherSmallThan127);System.out.println(SmallThan127.equals(anotherSmallThan127));Integer biggerThan127=new Integer(365);Integer anotherBiggerThan127=new Integer(365);System.out.println(anotherBiggerThan127==biggerThan127);System.out.println(anotherBiggerThan127.equals(biggerThan127));} }
请问结果是什么?
正确答案是
falsetrue
false
true
为什么会这样?
公布答案吧
3.1 ==的不同使用方法
==当两边都是对象的时候,会比较对象;
==当不都是对象时,会进行拆箱比较
3.2 equal时,进行值得比较,源码如下:
/*** Compares this object to the specified object. The result is* {@code true} if and only if the argument is not* {@code null} and is an {@code Integer} object that* contains the same {@code int} value as this object.** @param obj the object to compare with.* @return {@code true} if the objects are the same;* {@code false} otherwise.*/public boolean equals(Object obj) {if (obj instanceof Integer) {return value == ((Integer)obj).intValue();}return false;}
如果能经受住上面三轮暴击,看到最后的,你有成为优秀的程序员的潜质了,恭喜你了!
参考资料
【1】https://docs.oracle.com/javase/specs/jls/se12/html/jls-5.html#jls-5.1.7
【2】https://docs.oracle.com/javase/specs/jls/se12/html/jls-15.html#jls-15.25
转载于:https://www.cnblogs.com/davidwang456/p/11423996.html
总结
以上是生活随笔为你收集整理的java Integer中隐藏的细节魔鬼!来自面试官的三轮暴击!的全部内容,希望文章能够帮你解决所遇到的问题。
- 上一篇: 小米亿级大数据实时分析与工具选型 【转】
- 下一篇: 菜鸟、普通、老鸟程序猿如何写奇数判断?-