基础知识点
在Java中,== 运算符的行为取决于操作数的类型:
- 基本类型(如int, long, float等):==用于比较两个基本类型变量的值是否相等。
- 对象引用(如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或其他任何地方,这一规则都适用。