zoukankan      html  css  js  c++  java
  • 【转】合并两个List并去掉重复项

     原文:https://my.oschina.net/jack90john/blog/1493170

    工作中很多时候需要用到合并两个List并去除其中的重复内容。这是一个很简单的操作,这里主要是记录一下通过用Stream来完成这项操作。

        在java8之前比较常规的做法是将两个List添加到一个Set中,因为Set的内容不可重复,所以会自动去重,然后再由Set转为List,代码如下:

            Set<String> set = new HashSet<>(listA);
            set.addAll(listB);
            List<String> list = new ArrayList<>(set);
            System.out.println(list);

    这样做后的list就是合并并去重后的结果。

        在java8出现以后,我们有了更方便高效的做法,就是通过Stream来帮我们完成这项操作,代码如下:

    List<String> collect = Stream.of(listA, listB)
                    .flatMap(Collection::stream)
                    .distinct()
                    .collect(Collectors.toList());

    这样得到的结果也是最后我们想要的结果,可以很清楚的看出通过Stream完成的代码看上去更加简洁流畅。

    温馨提示:如果要合并的是对象请注意重写equals和hashcode方法。

    附:

    完整代码,以便参考。

    import java.util.*;
    import java.util.stream.Collectors;
    import java.util.stream.Stream;
    
    public class Combine {
    
        public static void main(String[] args) {
    
            String[] arr1 = {"a", "b", "c", "d", "e", "f"};
            List<String> listA = new ArrayList<>(Arrays.asList(arr1));
    
            String[] arr2 = {"d", "e", "f", "g", "h"};
            List<String> listB = new ArrayList<>(Arrays.asList(arr2));
    
            Set<String> set = new HashSet<>(listA);
            set.addAll(listB);
            List<String> list = new ArrayList<>(set);
            System.out.println(list);
    
            List<String> collect = Stream.of(listA, listB)
                    .flatMap(Collection::stream)
                    .distinct()
                    .collect(Collectors.toList());
            System.out.println(collect);
        }
    
    }
  • 相关阅读:
    mybatis 动态sql
    linux shell 之 crontab(定时任务)详解
    FTP定时批量下载文件(SHELL脚本及使用方法 )
    腾讯云数据库团队:MySQL5.7 JSON实现简单介绍
    Chisel Tutorial(七)——模块
    大数问题解决模板
    可靠的功能測试--Espresso和Dagger2
    hdoj 1698 Just a Hook 【线段树 区间更新】
    平衡二叉树
    WPF中DependencyObject与DependencyProperty的源代码简单剖析
  • 原文地址:https://www.cnblogs.com/zdd-java/p/11269455.html
Copyright © 2011-2022 走看看