关于在 Stream 的 anyMatch() 方法中比较两个对象相同数值的 Integer 类型属性(4040)时返回 false 的记录

基础知识点

在Java中,== 运算符的行为取决于操作数的类型:

  1. 基本类型(如int, long, float等):==用于比较两个基本类型变量的值是否相等。
  2. 对象引用(如Integer, String, User等类的实例):== 用于比较两个对象引用是否指向同一个对象,即它们是否具有相同的内存地址。这是因为 == 在对象上实际上比较的是引用,而不是对象的内容。

当我们在Java中使用Integer这样的包装类时,==的这种行为变得尤为重要。

例如:

Integer a = 100; // 自动装箱
Integer b = 100; // 自动装箱
System.out.println(a == b); // 输出true,因为100在-128到127的范围内,会被缓存复用

Integer c = 1000; // 自动装箱
Integer d = 1000; // 自动装箱
System.out.println(c == d); // 输出false,因为1000超出了缓存范围,每次赋值都会创建新的对象

在Stream的anyMatch方法中,当你使用 == 来比较Integer对象时,你实际上是在比较它们的引用,而不是它们的值。如果你的Stream中的元素是Integer对象,那么 == 将检查这些对象是否是同一个实例。

拓展

其他地方的情况
在任何使用 == 来比较对象的地方,你都应该意识到它比较的是引用,而不是对象的内容。这不仅仅发生在Stream中,而是整个Java语言的一致行为。
例如,下面的代码展示了在普通循环中 == 的使用:

List<Integer> list = Arrays.asList(100, 200, 100);
Integer target = 100;
for (Integer i : list) {
    if (i == target) {
        System.out.println("Found using ==");
        break;
    }
}

for (Integer i : list) {
    if (i.equals(target)) {
        System.out.println("Found using equals");
        break;
    }
}

在第一个循环中,i == target可能不会找到100,除非list中的Integer对象和target是同一个实例。而在第二个循环中,i.equals(target)将会正确地找到100,因为它比较的是值,而不是引用。

总结

在Java中,== 用于比较基本类型的值和对象引用的地址。要比较对象的内容,你应该使用equals方法,除非你明确想要比较对象引用是否相同。在使用Stream或其他任何地方,这一规则都适用。

  • 5
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值