equals和==

equals和==的区别小结

==:

== 比较的是变量(栈)内存中存放的对象的(堆)内存地址,用来判断两个对象的地址是否相同,即是否是指相同一个对象。比较的是真正意义上的指针操作。

1、比较的是操作符两端的操作数是否是同一个对象
2、两边的操作数必须是同一类型的(可以是父子类之间)才能编译通过。
3、比较的是地址,如果是具体的阿拉伯数字的比较,值相等则为true,如:
int a=10 与 long b=10L 与 double c=10.0都是相同的(为true),因为他们都指向地址为10的堆。

equals:

  equals用来比较的是两个对象的内容是否相等,由于所有的类都是继承自java.lang.Object类的,所以适用于所有对象,如果没有对该方法进行覆盖的话,调用的仍然是Object类中的方法,而Object中的equals方法返回的却是==的判断。

  String s="abce"是一种非常特殊的形式,和new 有本质的区别。它是java中唯一不需要new 就可以产生对象的途径。以String s="abce";形式赋值在java中叫直接量,它是在常量池中而不是象new一样放在压缩堆中。这种形式的字符串,在JVM内部发生字符串拘留,即当声明这样的一个字符串后,JVM会在常量池中先查找有有没有一个值为"abcd"的对象,如果有,就会把它赋给当前引用.即原来那个引用和现在这个引用指点向了同一对象,如果没有,则在常量池中新创建一个"abcd",下一次如果有String s1 = "abcd";又会将s1指向"abcd"这个对象,即以这形式声明的字符串,只要值相等,任何多个引用都指向同一对象.
  而String s = new String("abcd");和其它任何对象一样.每调用一次就产生一个对象,只要它们调用。

  也可以这么理解: String str = "hello"; 先在内存中找是不是有"hello"这个对象,如果有,就让str指向那个"hello".如果内存里没有"hello",就创建一个新的对象保存"hello". String str=new String ("hello") 就是不管内存里是不是已经有"hello"这个对象,都新建一个对象保存"hello"。

具体可以看下面的代码:

复制代码
 1 public class test1 {
 2     public static void main(String[] args) {
 3         String a = new String("ab"); // a 为一个引用
 4         String b = new String("ab"); // b为另一个引用,对象的内容一样
 5         String aa = "ab"; // 放在常量池中
 6         String bb = "ab"; // 从常量池中查找
 7         if (aa == bb) // true
 8             System.out.println("aa==bb");
 9         if (a == b) // false,非同一对象
10             System.out.println("a==b");
11         if (a.equals(b)) // true
12             System.out.println("aEQb");
13         if (42 == 42.0) { // true
14             System.out.println("true");
15         }
16     }
17 }
复制代码

equals和==的区别

equals方法最初是在所有类的基类Object中进行定义的,源码是

1
2
3
public  boolean  equals(Object obj) {
     return  ( this  == obj);
     }

  由equals的源码可以看出这里定义的equals与==是等效的(Object类中的equals没什么区别),不同的原因就在于有些类(像String、Integer等类)对equals进行了重写,但是没有对equals进行重写的类(比如我们自己写的类)就只能从Object类中继承equals方法,其equals方法与==就也是等效的,除非我们在此类中重写equals。

  对equals重新需要注意五点:

  1   自反性:对任意引用值X,x.equals(x)的返回值一定为true;
  2   对称性:对于任何引用值x,y,当且仅当y.equals(x)返回值为true时,x.equals(y)的返回值一定为true;
  3   传递性:如果x.equals(y)=true, y.equals(z)=true,则x.equals(z)=true ;
  4   一致性:如果参与比较的对象没任何改变,则对象比较的结果也不应该有任何改变;
  5   非空性:任何非空的引用值X,x.equals(null)的返回值一定为false 。

 

String类对equals的重写如下:

复制代码
 1 public boolean equals(Object anObject) {
 2     if (this == anObject) {
 3         return true;
 4     }
 5     if (anObject instanceof String) {
 6         String anotherString = (String)anObject;
 7         int n = count;
 8         if (n == anotherString.count) {
 9         char v1[] = value;
10         char v2[] = anotherString.value;
11         int i = offset;
12         int j = anotherString.offset;
13         while (n-- != 0) {
14             if (v1[i++] != v2[j++])
15             return false;
16         }
17         return true;
18         }
19     }
20     return false;
21     }
复制代码

  

  另外,"=="比"equals"运行速度快,因为"=="只是比较引用。

 

文章参考自:http://www.cnblogs.com/ok-lanyan/archive/2012/11/22/2782337.html

      http://www.cnblogs.com/shenliang123/archive/2012/04/16/2452156.html

<think>好的,我现在需要回答用户关于Java中equals方法==运算符的区别及使用场景的问题。首先,我需要回顾已有的知识,并结合用户提供的引用资料来确保答案的准确性。 用户引用了四个资料,其中引用[2]、[3]、[4]都是关于Java中equals==的区别,而引用[1]是关于C#的,可能可以忽略,因为用户的问题集中在Java上。我需要仔细阅读这些引用内容,提取关键点。 首先,根据引用[2],==比较的是对象的引用(地址),而equals默认比较的也是引用,但可以重写来比较内容。此外,==是运算符,equals是方法,==速度更快。引用[3]补充了对于基本数据类型,==比较值,对于对象则是地址;而String类的equals比较字符序列。引用[4]则提供了如何重写equals方法的例子,强调自定义对象内容比较时需要重写equals。 接下来,我需要组织这些信息,分点说明区别使用场景。可能需要分为功能差异、比较对象类型、性能、以及使用场景几个部分。同时,需要举例说明,比如字符串比较的例子,以及自定义对象的例子,这样用户更容易理解。 需要注意的是,用户可能对基本数据类型引用类型的区别不太清楚,需要明确说明。例如,==在基本类型时比较值,在引用类型比较地址;而equals用于对象内容比较,但默认行为需要重写。 另外,要确保使用正确的中文术语,避免技术术语错误。比如,“引用”“地址”需要准确对应。同时,检查是否有遗漏点,比如String类的特殊情况,以及如何正确重写equals方法,包括处理null类型检查等步骤。 最后,生成相关问题,可能需要包括为什么String的equals比较内容,如何正确重写equals方法,以及何时使用==equals的场景例子等。</think>### Java中equals方法与==运算符的区别及使用场景 #### 一、核心区别 1. **功能差异** - `==` 是**运算符**,用于比较两个变量的**存储地址是否相同**(引用类型)或**值是否相等**(基本数据类型)[^2][^3]。 - `equals()` 是**方法**,默认实现与 `==` 相同(比较地址),但可通过重写实现**对象内容的比较**[^4]。 2. **适用对象类型** - **基本数据类型**(如 `int`, `char`):只能用 `==` 比较值。 - **引用类型**(如 `String`, 自定义类): - `==` 比较对象的内存地址。 - `equals()` 比较对象内容(需重写方法)[^3][^4]。 3. **性能差异** - `==` 直接比较地址或值,速度更快。 - `equals()` 可能涉及复杂逻辑(如遍历字符串字符),效率较低[^3]。 #### 二、典型示例 1. **字符串比较** ```java String s1 = new String("hello"); String s2 = new String("hello"); System.out.println(s1 == s2); // false(地址不同) System.out.println(s1.equals(s2)); // true(内容相同)[^3] ``` 2. **自定义对象** ```java class Person { String name; int age; @Override public boolean equals(Object obj) { if (this == obj) return true; // 地址相同直接返回true if (obj == null || getClass() != obj.getClass()) return false; Person p = (Person) obj; return age == p.age && name.equals(p.name); // 比较内容[^4] } } ``` #### 三、使用场景 | **场景** | **使用方式** | **说明** | |-------------------------|--------------------|-----------------------------| | 基本数据类型比较 | `==` | 如 `int a=5; if(a == 5)` | | 引用类型地址比较 | `==` | 判断是否为同一个对象实例 | | 对象内容比较(如String) | `equals()` | 需确保类已正确重写equals方法 | | 自定义对象内容比较 | 重写`equals()` | 需同时重写`hashCode()`方法 | #### 四、注意事项 1. **重写`equals()`的规范**: - 自反性:`x.equals(x)` 必须为 `true`。 - 对称性:若 `x.equals(y)` 为 `true`,则 `y.equals(x)` 也需为 `true`。 - 一致性:多次调用结果不变(不依赖可变状态)。 - 非空性:`x.equals(null)` 必须为 `false`[^4]。 2. **`hashCode()`的关联**: 重写 `equals()` 时必须同时重写 `hashCode()`,以确保在哈希表(如 `HashMap`)中行为一致。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值