Java中==对基本类型比较值,对对象比较引用地址;对象内容比较应使用equals(),且重写equals()时必须重写hashCode()以保证哈希集合的正确性。

在Java里,
==
int
boolean
double
String
要搞清楚Java里
==
1. 基本数据类型(Primitive Types)的比较: 当涉及到
int
long
float
double
char
byte
short
boolean
==
int a = 10; int b = 10; System.out.println(a == b); // 输出 true char c1 = 'A'; char c2 = 'A'; System.out.println(c1 == c2); // 输出 true boolean flag1 = true; boolean flag2 = false; System.out.println(flag1 == flag2); // 输出 false
这没什么好说的,符合直觉。
2. 对象(Object Types)的比较: 这才是
==
String
Integer
double
==
String s1 = new String("hello");
String s2 = new String("hello");
System.out.println(s1 == s2); // 输出 false
String s3 = "world"; // 字符串字面量,会进入常量池
String s4 = "world"; // s4会引用常量池中与s3相同的对象
System.out.println(s3 == s4); // 输出 true
Object obj1 = new Object();
Object obj2 = new Object();
System.out.println(obj1 == obj2); // 输出 false
// 即使内容相同,只要是两个不同的对象,== 就返回false你可能会疑惑,
s3 == s4
true
new String()
立即学习“Java免费学习笔记(深入)”;
所以,如果你想比较两个对象的内容是否相等,几乎总是应该使用它们的
equals()
==
==
说实话,
==
String
最典型的例子就是字符串。一个初学者写下
if (myString == "某个值")
myString
"某个值"
String
String user_input = new Scanner(System.in).nextLine(); // 假设用户输入 "admin"
String expected_value = "admin";
// 这是一个常见的错误示范!
if (user_input == expected_value) {
System.out.println("匹配成功 (可能是巧合或者字符串常量池的魔术)");
} else {
System.out.println("匹配失败 (更常见的结果)");
}
// 正确的做法
if (user_input.equals(expected_value)) {
System.out.println("匹配成功 (内容相等)");
}这种设计并非Java的“缺陷”,而是其对引用类型和值类型的区分。
==
equals()
==
包装类,比如
Integer
long
boolean
==
Java为了性能优化,对一些常用的包装类值进行了缓存。例如,
Integer
-128
127
Integer
Integer i1 = 100; // 自动装箱,从缓存获取 Integer i2 = 100; // 自动装箱,从缓存获取 System.out.println(i1 == i2); // 输出 true (因为100在缓存范围内,引用的是同一个对象) Integer i3 = 200; // 自动装箱,不在缓存范围内,创建新对象 Integer i4 = 200; // 自动装箱,不在缓存范围内,创建新对象 System.out.println(i3 == i4); // 输出 false (两个不同的对象) // 显式创建新对象,即使值在缓存范围内,也会创建新对象 Integer i5 = new Integer(100); Integer i6 = new Integer(100); System.out.println(i5 == i6); // 输出 false
这真的是一个非常隐蔽的坑。我个人就见过不少代码因为不了解这个缓存机制,在比较
Integer
==
equals()
Integer val1 = 200; Integer val2 = 200; System.out.println(val1.equals(val2)); // 输出 true,这是正确的比较方式
equals()
当你需要比较两个对象的“内容”或“语义”是否相等时,就应该使用
equals()
Object
==
equals()
何时使用 equals()
String
Person
ArrayList
HashSet
如何正确重写 equals()
equals()
Object
null
x
x.equals(x)
true
null
x
y
y.equals(x)
true
x.equals(y)
true
null
x
y
z
x.equals(y)
true
y.equals(z)
true
x.equals(z)
true
null
x
y
equals
x.equals(y)
null
x
x.equals(null)
false
此外,一个非常重要的最佳实践是:如果重写了 equals()
hashCode()
HashSet
HashMap
hashCode()
equals()
equals()
hashCode()
一个简单的
Person
equals()
hashCode()
import java.util.Objects; // Java 7+ 引入的 Objects.equals 和 Objects.hash 简化了代码
class Person {
private String name;
private int age;
public Person(String name, int age) {
this.name = name;
this.age = age;
}
public String getName() { return name; }
public int getAge() { return age; }
@Override
public boolean equals(Object o) {
// 1. 检查是否是同一个对象引用,这是最快的判断
if (this == o) return true;
// 2. 检查传入对象是否为null,以及类型是否匹配
// getClass() 比 instanceof 更严格,要求类型完全一致
if (o == null || getClass() != o.getClass()) return false;
// 3. 类型转换
Person person = (Person) o;
// 4. 比较关键字段
// 基本类型直接比较值
// 引用类型使用其 equals 方法比较
return age == person.age && Objects.equals(name, person.name);
}
@Override
public int hashCode() {
// 使用 Objects.hash() 可以方便地为多个字段生成哈希码
return Objects.hash(name, age);
}
@Override
public String toString() {
return "Person{" +
"name='" + name + '\'' +
", age=" + age +
'}';
}
}
// 使用示例
// Person p1 = new Person("张三", 30);
// Person p2 = new Person("张三", 30);
// System.out.println(p1.equals(p2)); // 输出 true
// System.out.println(p1 == p2); // 输出 false正确重写
equals()
hashCode()
以上就是java如何用==判断两个值是否相等 java比较语句的基础教程的详细内容,更多请关注php中文网其它相关文章!
java怎么学习?java怎么入门?java在哪学?java怎么学才快?不用担心,这里为大家提供了java速学教程(入门到精通),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号