Java中List集合去重

反问问题:为什么不直接使用 Set 或者 LinkedHashSet 呢

实际场景:实际的业务开发中遇到的情况会更复杂。比如,List 集合可能是历史遗留问题,也有可能是调用接口返回的类型限制,只能使用 List 接收,又或者是代码写了一半,在做多个集合合并的时候才发现了这个问题

文章目录

1、contains判断去重(有序)

此方法的优点的:理解起来比较简单,并且最终得到的集合也是有序的,这里的有序指的是新集合的排列顺序和原集合的顺序是一致的;但缺点是实现代码有点多,不够简洁优雅。

cpp 复制代码
package com.atguigu.structure;

import java.util.ArrayList;
import java.util.List;
public class ListContains {

    /**
     * 获取一个特殊的测试列表
     * 该方法创建一个包含1到10000的数字字符串的列表,并且每个数字字符串出现两次
     * 首先,正序添加1到10000的数字字符串,然后逆序添加10000到1的数字字符串
     *
     * @return 返回一个特殊的测试列表,包含1到10000的数字字符串各两次
     */
    public static List<String> getTestList() {
        // 创建一个ArrayList来存储数字字符串
        List<String> list = new ArrayList<>();

        // 正序生成1到10000的数字字符串,并添加到列表中
        for (int i = 1; i <= 10000; i++) {
            list.add(String.valueOf(i));
        }

        // 逆序生成10000到1的数字字符串,并添加到列表中
        for (int i = 10000; i >= 1; i--) {
            list.add(String.valueOf(i));
        }

        // 返回生成的测试列表
        return list;
    }

    /**
     * 使用 contains 方法对列表进行去重
     *
     * @param testList 待去重的列表
     */
    private static void useContainsDistinct(List<String> testList) {
        // 输出去重开始前的列表条数
        System.out.println("contains 开始去重,条数:" + testList.size());
        // 创建一个新的列表用于存储去重后的元素
        List<String> newList = new ArrayList<>();
        // 遍历原始列表中的每个元素
        for (String s : testList) {
            // 如果新列表中不存在当前元素,则将该元素添加到新列表中
            if (!newList.contains(s)) {
                newList.add(s);
            }
        }
        // 输出去重结束后的列表条数
        System.out.println("contains 结束去重,条数:" + newList.size());
    }


    /**
     * 程序的主入口点
     * 这个方法用于演示和测试含有去重操作的方法useContainsDistinct
     * @param args 命令行参数
     */
    public static void main(String[] args) {
        // 获取待进行去重测试的列表
        List<String> testList = getTestList();

        // 记录开始去重操作的时间
        long startTime = System.currentTimeMillis();

        // 使用contains方法进行去重操作
        useContainsDistinct(testList);

        // 记录结束去重操作的时间
        long endTime = System.currentTimeMillis();

        // 输出去重操作所消耗的时间
        System.out.println("contains 去重耗时:" + (endTime - startTime) + "毫秒");
    }


}
cpp 复制代码
contains 开始去重,条数:20000
contains 结束去重,条数:10000
contains 去重耗时:364毫秒
相关推荐
武子康5 分钟前
Java-181 OSS 实战指南:Bucket/外链/防盗链/计费与常见坑
java·大数据·分布式·oss·云存储·fastdfs·ali
聆风吟º5 分钟前
【Spring Boot 报错已解决】告别“Whitelabel Error Page”:Spring Boot 404报错的排查指南
java·spring boot·后端
w10463672p6 分钟前
java解析CSV文件(一)——Java使用Apache.Commons.CSV解析CSV文件应用实践
java·apache·springboot·csv
weixin_307779138 分钟前
Jenkins Gson API插件:统一JSON处理的基础库
java·运维·开发语言·架构·jenkins
高频交易dragon9 分钟前
python缠论形态分析过程
开发语言·网络·python
fufu031110 分钟前
Linux环境下的C语言编程(三十六)
linux·c语言·开发语言·数据结构·算法
rit843249916 分钟前
LTE系统资源分配MATLAB实现示例(基于OFDMA的动态调度)
开发语言·matlab
Tony66668888819 分钟前
Webservic 服务注册发布及参数封装-实际项目应用
java·spring·servlet
老华带你飞22 分钟前
零食商城|基于springboot + vue零食商城管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·毕设
chilavert31825 分钟前
技术演进中的开发沉思-231 Ajax:页面内容修改
开发语言·前端·javascript