首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

为什么 Java 中 1000==1000 为 false ?

来源:Java高效学习 这是一个挺有意思的讨论话题。...1000; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用 == 表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是 false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是: Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的 “小” 整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射 API 你会误用此功能。

41220

为什么 Java 中 1000==1000 为 false ?

来源:Java高效学习 这是一个挺有意思的讨论话题。...1000; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用 == 表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是 false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是: Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的 “小” 整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射 API 你会误用此功能。

60750
  • 您找到你想要的搜索结果了吗?
    是的
    没有找到

    Java中“100=100”为true,而1000=1000为false?

    为什么会产生这样的结果呢? 1 Integer对象 上面例子中的a和b,是两个Integer对象。 而非Java中的8种基本类型。...在JVM中的内存分布情况是下面这样的: 在栈中创建了两个局部变量a和b,同时在堆上new了两块内存区域,他们存放的值都是1000。 变量a的引用指向第一个1000的地址。...Integer a = 100; Integer b = 100; System.out.println(a==b); 不应该也返回false吗? 对象a和b的引用不一样。...文章示例中的1000,超出了-128~127的范围,所以对象a和b的引用指向了两个不同的地址。 而示例中的100,在-128~127的范围内,对象a和b的引用指向了同一个地址。...因此下面的执行结果是:false。

    29310

    为什么 Java 中“1000==1000”为false,而”100==100“为true?

    这是一个挺有意思的讨论话题。...; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到: false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是 Integer i = Integer.valueOf(100); 现在,...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。 运行下面的代码,享受它的魅力吧!

    53120

    为什么Java中1000==1000为false,而100==100为true?

    ; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是 Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。...Java 改用 Kotlin 的六个月后,我后悔了!

    61420

    为什么 Java 中“1000==1000”为false,而”100==100“为true?

    这是一个挺有意思的讨论话题。...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到: false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是 Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。 运行下面的代码,享受它的魅力吧!

    48810

    为什么Java中1000==1000为false而100==100为true?

    这是一个挺有意思的讨论话题。...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是: Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。

    60640

    为什么 Java 中1000==1000为false,而100==100为true?

    这是一个挺有意思的讨论话题。...1000; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用 == 表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是 false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是: Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的 “小” 整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射 API 你会误用此功能。

    35710

    为什么 Java 中“1000==1000”为false,而”100==100“为true?

    这是一个挺有意思的讨论话题。...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到: false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是 Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。 运行下面的代码,享受它的魅力吧!

    47130

    为什么Java中1000==1000为false而100==100为true?

    这是一个挺有意思的讨论话题。...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是 Integer i = Integer.valueOf(100); 现在,...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。

    58820

    为什么Java中“1000==1000”为false,而”100==100“为true?

    在日常编程中,我们经常遇到一些看似简单却隐藏着复杂逻辑的问题。 比如,你是否想过为什么在 Java 中表达式1000==1000会返回 false,而 100==100 却返回 true 呢?...很明显,我们得看 Integer 类的 valueOf 方法: 继续看 IntegerCache : 为了防止大家不好理解,我这里为这个方法添加了详细注释: private static class IntegerCache...// 默认情况下,缓存的上界是127 int h = 127; // 尝试从系统属性java.lang.Integer.IntegerCache.high中获取自定义的上界值...这个 IntegerCache 是在 Java 的 Integer 类中的一个内部静态类 ,它缓存了 -128 到 127 之间的整数。...相反,“1000”不在缓存范围内,即使数值相同,两个“1000”也是不同的对象,因此内存地址不同,返回 false。

    20210

    为什么 Java 中“1000==1000”为false,而”100==100“为true?

    英文原文:http://dwz.date/crTP 这是一个挺有意思的讨论话题,大家可以,动手实操一下。 为什么 Java 中“1000==1000”为false,而”100==100“为true?...这是一个挺有意思的讨论话题。...; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用 == 表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是 false 。 这就是它有趣的地方了。...合乎逻辑的理由是,在此范围内的 “小” 整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射 API 你会误用此功能。

    59840

    为什么 Java 中“1000==1000”为false,而”100==100“为true?

    www.codeceo.com/article/why-java-1000-100.html 英文原文:https://dzone.com/articles/why-1000-1000-returns-false-but...-100-100-returns-tr 为什么 Java 中“1000==1000”为false,而”100==100“为true?...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。

    51110

    为什么Java中1000==1000为false而100==100为true?

    原文:Why 1000 == 1000 Returns False, but 100 == 100 Returns True in Java?...1000; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到: false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是: Integer i = Integer.valueOf(100); 现在...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。

    73270

    为什么Java中1000==1000为false而100==100为true?

    这是一个挺有意思的讨论话题。...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是 Integer i = Integer.valueOf(100); 现在,...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。

    55130

    为什么Java中1000==1000为false而100==100为true?

    这是一个挺有意思的讨论话题。...1000; System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到: false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...所以事情就成了,所有的小整数在内部缓存,然后当我们声明类似—— Integer c = 100; 的时候,它实际上在内部做的是: Integer i = Integer.valueOf(100);...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。

    53840

    问号脸:为什么 Java 中 “1000==1000” 为 false,而 ”100==100“ 为 true?

    为什么 Java 中“1000==1000”为false,而”100==100“为true? 这是一个挺有意思的讨论话题。...System.out.println(a == b);//1 Integer c = 100, d = 100; System.out.println(c == d);//2 你会得到 false...如果两个引用指向不同的对象,用==表示它们是不相等的,即使它们的内容相同。 因此,后面一条语句也应该是false 。 这就是它有趣的地方了。...合乎逻辑的理由是,在此范围内的“小”整数使用率比大整数要高,因此,使用相同的底层对象是有价值的,可以减少潜在的内存占用。 然而,通过反射API你会误用此功能。...www.codeceo.com/article/why-java-1000-100.html 英文原文:https://dzone.com/articles/why-1000-1000-returns-false-but

    56320

    深入探究Flutter中的页面导航器:Navigator详解

    介绍 在移动应用开发中,导航器(Navigator)是一个至关重要的组件,它负责管理应用程序中各个页面之间的导航和转换。...在Flutter中,Navigator扮演着非常重要的角色,它允许我们在应用程序中进行页面的跳转、返回以及传递参数等操作,为用户提供了流畅、高效的导航体验。...导航器嵌套 在Flutter应用中,有时我们需要在一个页面内部管理多个子页面,这时就可以使用导航器嵌套的技术。...导航器嵌套允许我们在一个页面内部创建多个导航器,并分别管理它们之间的导航栈,从而实现更灵活和复杂的页面管理。本节将学习如何在Flutter应用中实现导航器的嵌套,并演示如何在多个导航器之间进行导航。...Navigator作为Flutter中页面导航的核心组件,承担着管理页面路由栈、实现页面间跳转和过渡动画等重要功能,为我们开发Flutter应用提供了强大的支持。

    1.4K20

    在匹配过程中为什么将 found 重置为 False?

    在匹配过程中,将 found 变量重置为 False 通常用于循环或递归结构中以重新初始化某些状态。...2、解决方案found = False 的赋值语句用于在每次循环迭代结束后,将 found 变量重置为 False。...这是因为在新一轮迭代开始时,需要确保 found 变量为 False,以确保程序能够正确地根据用户输入的查询条件查找匹配项。...为了解决这个问题,需要在每次循环迭代结束后,将 found 变量重置为 False。这样,程序才能正确地根据用户输入的查询条件查找匹配项,并在页面上显示找到的结果。...found 变量在每次循环迭代结束后都重置为 False,因此程序能够正确地根据用户输入的查询条件查找匹配项,并在页面上显示找到的结果。

    7410
    领券