文章详情

短信预约-IT技能 免费直播动态提醒

请输入下面的图形验证码

提交验证

短信预约提醒成功

Java中Stream流去除List重复元素的方法

2024-04-02 19:55

关注

本文实例为大家分享了Java中Stream流去除List重复元素的具体代码,供大家参考,具体内容如下

业务场景

在开发中我们常常需要过滤List中的重复对象,而重复的定义往往是根据单个条件或者多个条件,如果是单个条件的话还是比较好处理的,即使不使用工具,代码也可以很容易实现,但如果判断依据不是单个条件,而是多个条件的话,代码实现起来就会比较复杂,此时我们一般就会使用工具来简化开发

单条件去重代码

ArrayList<listData> collect = list.stream().collect(Collectors.collectingAndThen(
          Collectors.toCollection(() -> new TreeSet<>(
            Comparator.comparing(
        listData::getId))), ArrayList::new));

解释

list-列表
listData-列表中存的对象
id是判断是否重复的条件,只保留唯一id对象

多条件去重代码

ArrayList<listData> collect = list.stream().collect(Collectors.collectingAndThen(
     Collectors.toCollection(() -> new TreeSet<>(
       Comparator.comparing(p->p.getPatentName() + ";" + p.getLevel()))), ArrayList::new));

测试代码

import java.util.*;
import java.util.stream.Collectors;

public class ExcelUtil {

    private static String[] params = {"p001","p002","p003","p004"};

    public static void main(String[] args) {

        List<Datum> dataList = new ArrayList<>();

        for (int i = 0; i < 100; i++) {
            if (i%2==0){
                Datum datum = new Datum(
                        params[new Random().nextInt(params.length)],
                        params[new Random().nextInt(params.length)],
                        params[new Random().nextInt(params.length)],
                        params[new Random().nextInt(params.length)],
                        params[new Random().nextInt(params.length)]
                );
                dataList.add(datum);
            }
        }
        
        System.out.println("0 size : "+dataList.size()+" -> "+dataList);

        // 单条件
        ArrayList<Datum> collect1 = dataList.stream().collect(Collectors.collectingAndThen(
                Collectors.toCollection(() -> new TreeSet<Datum>(
                        Comparator.comparing(
                                Datum::getId))), ArrayList::new));

        System.out.println("1 size : "+collect1.size()+" -> "+collect1);

        // 两个条件
        ArrayList<Datum> collect2 = dataList.stream().collect(Collectors.collectingAndThen(
                Collectors.toCollection(() -> new TreeSet<>(
                        Comparator.comparing(p->p.getId() + ";" + p.getAddress()))), ArrayList::new));

        System.out.println("2 size : "+collect2.size()+" -> "+collect2);

        // 三个条件
        ArrayList<Datum> collect3 = dataList.stream().collect(Collectors.collectingAndThen(
                Collectors.toCollection(() -> new TreeSet<>(
                        Comparator.comparing(p->p.getInfo() + ";" + p.getAddress()+";"+p.getName()))), ArrayList::new));

        System.out.println("3 size : "+collect3.size()+" -> "+collect3);

    }

}

效果

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持编程网。

阅读原文内容投诉

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

软考中级精品资料免费领

  • 历年真题答案解析
  • 备考技巧名师总结
  • 高频考点精准押题
  • 2024年上半年信息系统项目管理师第二批次真题及答案解析(完整版)

    难度     801人已做
    查看
  • 【考后总结】2024年5月26日信息系统项目管理师第2批次考情分析

    难度     348人已做
    查看
  • 【考后总结】2024年5月25日信息系统项目管理师第1批次考情分析

    难度     311人已做
    查看
  • 2024年上半年软考高项第一、二批次真题考点汇总(完整版)

    难度     432人已做
    查看
  • 2024年上半年系统架构设计师考试综合知识真题

    难度     220人已做
    查看

相关文章

发现更多好内容

猜你喜欢

AI推送时光机
位置:首页-资讯-后端开发
咦!没有更多了?去看看其它编程学习网 内容吧
首页课程
资料下载
问答资讯