判断两个List是否相等

绝地灬酷狼 2022-08-30 00:40 458阅读 0赞

最近一位同学在面试时被问到如何比较两个list是否相等?Java中的list是按自然顺序排列的。因此,如果两个list包含相同顺序的完全相同的元素,则认为它们是相等的,如果忽略元素顺序怎么样去比较两个列表?

直接使用equals比较

众所周知,两个列表具有完全相同的元素并且具有完全相同的顺序时,它们是相等的。因此, 如果我们业务要求两个list顺序一致,可以使用equals()方法进行相等性检查。

  1. @Test
  2. public void equalityCheckOfTwoLists() {
  3. List<Integer> list1 = Arrays.asList(1, 2, 3);
  4. List<Integer> list2 = Arrays.asList(1, 2, 3);
  5. List<Integer> list3 = Arrays.asList(2, 1, 3);
  6. assertTrue(list1.equals(list2));
  7. assertFalse(list1.equals(list3));
  8. }

即使list1的项目list3包含相同的元素{1,2,3},但是元素顺序不一样,所以list1和list3还是不相等的。

注意: 有的业务元素的顺序不必要求一致,只看两个列表是否包含相同的元素,那如何去实现呢?

将list排序之后再比较

校验逻辑主要有:

(1) 如果两个list都为null,则返回true

(2)如果一个list不为空 ,另外一个指向值返回false

(3)两个list的size()不同 ,返回false

上面条件都不满足,我们就把两个list排序再进行比较:

  1. public <T extends Comparable<T>> boolean isEquals(List<T> list1, List<T> list2){
  2. if (list1 == null && list2 == null) {
  3. return true;
  4. }
  5. //Only one of them is null
  6. else if(list1 == null || list2 == null) {
  7. return false;
  8. }
  9. else if(list1.size() != list2.size()) {
  10. return false;
  11. }
  12. //copying to avoid rearranging original lists
  13. list1 = new ArrayList<T>(list1);
  14. list2 = new ArrayList<T>(list2);
  15. Collections.sort(list1);
  16. Collections.sort(list2);
  17. return list1.equals(list2);
  18. }

请注意:我们这里创建了两个列表的副本来保证原始列表中的元素保持不变。

使用Sets / contains()比较list

如果列表没有重复元素 ,我们可以使用list中创建TreeSet,然后使用equals()比较。

  1. public <T extends Comparable<T>> boolean isEquals(List<T> list1, List<T> list2){
  2. if (list1 == null && list2 == null) {
  3. return true;
  4. }
  5. //Only one of them is null
  6. else if(list1 == null || list2 == null) {
  7. return false;
  8. }
  9. else if(list1.size() != list2.size()) {
  10. return false;
  11. }
  12. Set<T> set1 = new TreeSet<>(list1);
  13. Set<T> set2 = new TreeSet<>(list2);
  14. return set1.equals(set2);
  15. }

我们甚至可以更加简单使用contains()比较,不用创建Sets

  1. return list1.containsAll(list2) && list2.containsAll(list1);

但是这里要注意 如果我们list元素存在重复,使用contains()或者Sets比较就会有问题。看下面这个案例你就知道怎么回事了。

  1. List<Integer> list1 = Arrays.asList(1, 2, 3, 3);
  2. List<Integer> list2 = Arrays.asList(3, 1, 2, 2);
  3. // will return true, but actual value should be false
  4. System.out.println(list1.isEquals(list2));

在上面的示例中,list1包含一个2和两个3,list2包含两个2和一个3,我们可以看到两个list其实是不相等的,但是程序会错误地返回true。所以使用这个方法时要确保list元素没有重复的

使用Apache Commons工具类

CollectionUtils提供了集合相等的判断工具方法isEqualCollection,只要我们确保两个集合非空可以直接使用该方法来判断集合相等。

  1. List<Integer> list1 = Arrays.asList(1, 2, 3, 3);
  2. List<Integer> list2 = Arrays.asList(3, 1, 3, 2);
  3. System.out.println(CollectionUtils.isEqualCollection(list1, list2)); //true

结论:

今天我们学习了Java比较两个列表是否相等4种方法,一般默认情况下,当两个列表具有相同顺序的相同元素时,我们就知道它们是相等的。如果我们对元素的顺序不太关心的话,可以采用其它几种方法进行列表相等性比较。这些方法你掌握了吗?

发表评论

表情:
评论列表 (有 0 条评论,458人围观)

还没有评论,来说两句吧...

相关阅读

    相关 判断List是否相等

    最近一位同学在面试时被问到如何比较两个list是否相等?Java中的list是按自然顺序排列的。因此,如果两个list包含相同顺序的完全相同的元素,则认为它们是相等的,如果忽略