JS Bin

Arrays中的euqals()和Object中的euqals()方法的区别(是否逐个遍历元素的值)

@dashenaichicha

Arrays中的euqals()和Object中的euqals()方法的区别(思考其是否逐个遍历的问题)

  如果我们得到了两个数组,int arr1[]和int arr2[],如果我们想要比较这两个数组是否里面的元素都是相等的,那么比较的思路应该是取出两个数组中的元素然后逐个进行比较才对,那么如果直接使用arr1.equals(arr2)能否实现这个过程:

  1. public class TestArrayEquals {  
  2.     static int arr1[] = { 12345 };  
  3.     static int arr2[] = { 12345 };  
  4.     
  5.     public static boolean compare(int a[], int b[]) {  
  6.         Boolean result = a.equals(b);  
  7.         return result;  
  8.     }  
  9.     
  10.     public static void main(String[] args) {  
  11.       System.out.println(TestArrayEquals.compare(arr1, arr2)); 
  12.     }  
  13.     
  14. }  

  测试的结果:

  我们看下其实定义的两个数组是两个对象,其实这调用的是object的equals()方法,在源码中:

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

 

  Object类,它是所有类的超类,两个对象进行比较,如果是基本数据类型,那么比较的是两个数的值是否相等,而对象比较的是地址值,如果没有重写equals方法,那么默认使用父类Object的equals方法,这个方法内部默认使用==进行对象的比较,对象是引用类型,而引用类型比较的是地址值,如果是两个不同的对象的话就会返回false。而这里就是调用了object的equals()方法,由于这两个数组是不同的对象,所以进行底层地址值比较的时候就会返回false。

  如果我们将上面的代码修改一下:

  1. import java.util.Arrays;  
  2.     
  3. public class TestArrayEquals {  
  4.     static int arr1[] = { 12345 };  
  5.     static int arr2[] = { 12345 };  
  6.     
  7.     public static boolean compare(int a[], int b[]) {  
  8.         Boolean result = a.equals(b);  
  9.         return result;  
  10.     }  
  11.     
  12.     public static void main(String[] args) {  
  13.         System.out.println(Arrays.equals(arr1, arr2));  
  14.     }  
  15.     
  16. }  

 

  我们直接调用的是Arrays工具类里面的equals方法,来比较我们上面的两个数组的话,就会得到下面的执行结果:

  Arrays工具类里面的equals方法是将传入的两个数组便利其中的元素,然后逐个比较其值是否相等:

  1. public static boolean equals(int[] a, int[] a2) {  
  2.         if (a==a2)  
  3.             return true;  
  4.         if (a==null || a2==null)  
  5.             return false;  
  6.     
  7.         int length = a.length;  
  8.         if (a2.length != length)  
  9.             return false;  
  10.     
  11.         for (int i=0; i<length; i++)  
  12.             if (a[i] != a2[i])  
  13.                 return false;  
  14.     
  15.         return true;  
  16. }  
posted @ 2019-11-26 10:23  左五六  阅读(274)  评论(0编辑  收藏  举报