侧边栏壁纸
博主头像
一个九零后的萤火虫博主等级

行动起来,活在当下

  • 累计撰写 33 篇文章
  • 累计创建 7 个标签
  • 累计收到 0 条评论

目 录CONTENT

文章目录

java基础知识面试坑系列(一) 你只知道一半的Integer类型== 和equals

Administrator
2024-01-25 / 0 评论 / 0 点赞 / 16 阅读 / 5087 字

0.前言

java作为中国互联网第一大应用语言,有着广泛的群众基础。正所谓:“面试造飞机,工作拧螺丝” 的国内面试氛围;很多java程序员通过baidu搜索面试题目和答案,达到快速通过面试的目的。

但是,其实百度出来的答案是不完整的,甚至是错误的,也有可能是某个jdk版本之前的知识点。本人特此整理一些文章来让新手避坑。不定期更新。jdk版本使用最多的JDK8。
1、你只知道一半的Integer类型== 和equals

baidu搜出来的文章一般如下:

integer缓存相关内容比较

/*

  • 举几个栗子比较一下
  • 说明:==是比较地址值,equals比较对象内容
  • 注意:Integer的数据直接赋值,如果在-128到127之间,会直接从缓冲池里获取数据
    */
    public static void main(String[] args) {
        Integer i1 = new Integer(127);
        Integer i2 = new Integer(127);
        System.out.println(i1 == i2);
        System.out.println(i1.equals(i2));
        System.out.println("-----华丽分割线------");

        Integer i3 = new Integer(128);
        Integer i4 = new Integer(128);
        System.out.println(i3 == i4);
        System.out.println(i3.equals(i4));
        System.out.println("-----华丽分割线------");

        Integer i5 = 128;
        Integer i6 = 128;
        System.out.println(i5 == i6);
        System.out.println(i5.equals(i6));
        System.out.println("-----华丽分割线------");

        Integer i7 = 127;
        Integer i8 = 127;
        System.out.println(i7 == i8);
        System.out.println(i7.equals(i8));
    }
}

运行结果如下
运行结果

jdk源码查看integer缓存,在 -128~127区间,直接拿缓存,之外才重新 new Integer(i);

my

my

那么关于源码中的assert又在什么时候用到呢?

assertion(断言)在软件开发中是一种常用的调试方式,很多开发语言中都支持这种机制。在实现中,assertion就是在程序中的一条语句,它对一个boolean表达式进行检查,一个正确程序必须保证这个boolean表达式的值为true;如果该值为false,说明程序已经处于不正确的状态下,assert将给出警告或退出。一般来说,assertion用于保证程序最基本、关键的正确性。assertion检查通常在开发和测试时开启。为了提高性能,在软件发布后,assertion检查通常是关闭的。


    public static void main(String[] args) {
        int i = 0;
        for (i = 0; i < 5; i++) {
            System.out.println(i);
        }
        // 假设程序不小心多了一句--i;
        --i;
        assert i == 5;
    }

}

上边这个答案不能说错,但是他是不完整的。

我们来看一下Integer的源代码,有一段注释
5

什么意思,就是你可以通过修改JVM启动参数,而修改这个缓存值。

我们用上边的例子来重新跑一下,看看最终结果,同时增加2个条件

        Integer i9 = -127;
        Integer i10 = -127;
        System.out.println(i9 == i10);
        System.out.println(i9.equals(i10));
        
        System.out.println("-----华丽分割线,-130------");
        Integer i11 = -130;
        Integer i12 = -130;
        System.out.println(i11 == i12);
        System.out.println(i11.equals(i12));

接下来增加jvm启动参数:
7

运行结果:
8
修改jvm参数后,正数 128 比较从false -> true。

我们在回头看看源代码:
9

根据逻辑可知,-XX:AutoBoxCacheMax=,这个jvm参数修改的是 Integer缓存的上限,也就是正数部分的最大值。负数下限只缓存到 -128。
3、综上结论:

完整答案为:


(0)在数据不超出Integer的范围内。

(1)在不修改jvm启动参数-XX:AutoBoxCacheMax=的前提下,本文上部分引用的答案是正确的。

(2)在修改-XX:AutoBoxCacheMax=之后,大于127的整数结果需要根据参数的值重新判断。

(3)负数部分结果不受影响

原文链接:https://blog.csdn.net/zhj149/article/details/103519815

0

评论区