想去除List重复元素?我有两种方法搞定,赶紧拿去用

news2024/11/18 11:21:45

关注“Java架构栈”微信公众号,回复暗号【Java面试题】即可获取大厂面试题

 问题背景

最近就有很多小伙伴在后台私信波哥,问波哥这样一个问题:“波哥,我最近正在找工作,被面试官问到List该怎么去重?我感觉自己的回答没有get到面试官的预期结果,请问波哥这个问题怎么回答才能让面试官满意呢?” 对于这个问题,波哥会建议大家采用JDK 8中的stream进行去重,为什么呢?请看接下来波哥给大家的分析吧。

 List去重方式

为了让大家能够比较完美地回答这个问题,波哥会给大家展示以下几种经典的去重方式。

2.1 迭代器去重

第一种方式,我们可以使用迭代器来循环判断每一项数据,如果当前循环到的数据,在集合中存在两份或两份以上,就将当前的元素删除掉。这样循环完之后,我们就可以得到一个没有重复数据的集合,这是一种比较常见的去重方式,其实现代码如下:

public class ListTest {
    public static void main(String[] args) {
       List<Integer> list = new ArrayList<Integer>() {{
        add(2); add(5); add(9);
        add(2); add(4); add(9);
        add(3); add(7); add(8);}};
        System.out.println("原list:"+list);
        test(list); 
    }
        
    public static void test(List<Integer> list){
        Iterator<Integer> iterator = list.iterator();
        while (iterator.hasNext()){
            Integer integer = iterator.next();
            if(list.indexOf(integer)!=list.lastIndexOf(integer)){
                iterator.remove();} 
                }
        System.out.println("新list:"+list); 
    }
 }

运行上面的代码会得到以下结果:

但是细心的你可以或许可以看到,在使用迭代器去重的时候,List结果的顺序是混乱的,跟原来的集合顺序并不一样,这如何搞?

2.2 Stream去重

这个时候,波哥就要给小伙伴介绍一种新的实现方案了。如果你可以回答出这一点,我相信面试官会满意的颔首的。这种实现方式,是利用JDK8为我们带来的Stream流。使用Stream可以让我们轻松地实现很多功能,比如下面的去重效果:

public class ListTest {
    public static void main(String[] args) {
       List<Integer> list = new ArrayList<Integer>() {{
        add(2); add(5); add(9);
        add(2); add(4); add(9);
        add(3); add(7); add(8);}};
        System.out.println("原list:"+list);
        test(list);
    }
    
    public static void test(List<Integer> list){
        list=list.stream().distinct().collect(Collectors.toList());
        System.out.println("新list:"+list); 
    }
}

现在你看,上面的实现代码比迭代器的实现方式更简单,运行上面的代码会得到以下结果:

而且利用stream()方法,我们不仅对运行结果实现了去重,还没有改变原来的集合元素顺序,保证了集合内容的有序性,这比传统的去重方式更简单有效,且性能也更高哦!

 小结

除了以上两种方式之外,其实我们还有一些别的方法也可以对List集合去重。本文波哥只是给大家讲解了以上两种,就当是抛砖引玉吧,如果你还知道别的方式,可以在评论区给出你的答案。今天的内容你学会了吗?关注Java架构栈,干货天天都不断!

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/670307.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

命令执行测试-业务安全测试实操(12)

命令执行测试 测试原理和方法 在应用需要调用一些外部程序去处理内容的情况下,就会用到一些执行系统命令的承数。如PHP中的svstem、exec、shell exec等,当用户可以控制命令执行函数中的参数时,将可注入恶意系统命令到正常命令中,造成命令执行攻击。测试中如果没有对参数(如…

Lowe‘s EDI 项目数据库方案开源介绍

近期为了帮助广大用户更好地使用 EDI 系统&#xff0c;我们根据以往的项目实施经验&#xff0c;将成熟的 EDI 项目进行开源。用户安装好知行之桥EDI系统之后&#xff0c;只需要下载我们整理好的示例代码&#xff0c;并放置在知行之桥指定的工作区中&#xff0c;即可开始使用。 …

Flutter如何使用mvi? bloc结合自定义http库的实现

文章目录 前言一、先看看如何使用bloc吧1. 定义页面需要的数据2. 定义通用加载状态3. 定义事件4. 定义bloc5. 定义UI6. 使用 二、lib_http1. request定义2. response定义3. 适配器接口4. 构建adapter需要的数据5. 网络异常统一封装6. 核心请求类7. 提供网络访问配置8. dio适配器…

编译原理笔记13:自上而下语法分析(3)构造预测分析表、LL(1) 文法

目录 构造预测分析表不懂也能用的构造步骤FIRST、FOLLOW 和分析表的原理&#xff1f; LL(1) 文法 构造预测分析表 预测分析表的作用&#xff0c;是为推导的进行指明方向——我们用当前下推栈栈顶和读写头所指向的符号的组合&#xff08;即当前的状态&#xff09;&#xff0c;去…

网络安全学习指南:新手入门建议

&#x1f482; 个人网站:【海拥】【游戏大全】【神级源码资源网】&#x1f91f; 前端学习课程&#xff1a;&#x1f449;【28个案例趣学前端】【400个JS面试题】&#x1f485; 寻找学习交流、摸鱼划水的小伙伴&#xff0c;请点击【摸鱼学习交流群】 目录 前言网络安全基础知识学…

IPv6:连接未来的新一代互联网协议

由于互联网发展迅猛&#xff0c;IPv4地址数量已经接近枯竭。IPv6应运而生&#xff0c;成为下一代互联网协议。IPv6较IPv4来说&#xff0c;地址容量上升了数倍&#xff0c;并有更好的安全性和效率。 IPv6&#xff08;Internet Protocol version 6&#xff09;是指新一代互联网协…

【Java】如何优雅的关闭线程池

文章目录 背景一、线程中断 interrupt二、线程池的关闭 shutdown 方法2.1、第一步&#xff1a;advanceRunState(SHUTDOWN) 把线程池置为 SHUTDOWN2.2、第二步&#xff1a;interruptIdleWorkers() 把空闲的工作线程置为中断2.3、 第三步&#xff1a;onShutdown() 一个空实现&…

PG系列2:Linux下yum安装PG 15

文章目录 一. 下载PG二. 开始安装2.1 安装数据库2.2 初始化数据库2.3 设置开机启动2.4 修改密码2.5 设置允许远程连接2.6 重启数据库服务2.7 修改数据库密码 三. 验证参考: 一. 下载PG 官网地址: https://www.postgresql.org/选择Download 选择CentOS 选择对应的版本 …

iOS 单元测试之常用框架 OCMock 详解

目录 前言&#xff1a; 一、单元测试 1.1 单元测试的必要性 1.2 单元测试的目的 1.3 单元测试依赖的两个主要框架 二、OCMock 的集成与使用 2.1 OCMock 的集成方式 2.2 OCMock 的使用方法 2.3 mock使用限制 三、最后 前言&#xff1a; 在iOS开发中&#xff0c;单元测…

OpenCV——实验结果输出《图像基本操作》

1.图像融合 图像融合主要使用的函数为 cv2.addWeighted() #图像融合 # img_cat img_dog #shapes (414,500,3) (429,499,3) img_dog cv2.resize(img_dog,(500,414))#resize函数&#xff0c;不考虑图像形变问题。 print(img_dog.shape) #两张图片的权重相同&#xff0c;gamm…

java编写金字塔

一、实心金字塔 首先&#xff0c;尝试写一个逐层加1个*的金字塔&#xff1a; 可以看出&#xff0c;每一层由空格和*组成&#xff0c;且空格*的总数为底部基石的数量&#xff0c;那么前后空格数就是&#xff08;底部基石数 - 各层星星数&#xff09;*1/2&#xff0c;然后拼接字…

C# 特性(Attribute)总结

目录 特性是什么&#xff1f; 如何使用特性&#xff1f; &#xff08;1&#xff09;.Net 框架预定义特性 &#xff08;2&#xff09;自定义特性 为什么要使用特性&#xff1f; 特性的应用 特性实现枚举展示描述信息 特性是什么&#xff1f; 特性&#xff08;Attribute&…

基于spss的多元统计分析 之 聚类分析+判别分析(2/8)

实验目的&#xff1a; 1&#xff0e;掌握聚类分析及判别分析的基本原理&#xff1b; 2&#xff0e;熟悉掌握SPSS软件进行聚类分析及判别分析的基本操作&#xff1b; 3&#xff0e;利用实验指导的实例数据&#xff0c;上机熟悉聚类分析及判别分析方法。 实验前预习&#xff1a;…

js中原型和原型链的理解(透彻)

js中原型、原型链、继承的理解&#xff08;透彻&#xff09; 1、前言1.1 什么是函数对象1.2 什么是实例对象1.3 什么是原型对象1.4 构造函数、原型对象、实例对象的关系 2、原型3、原型链4、原型的相关属性及方法5、总结 1、前言 1.1 什么是函数对象 函数对象就是我们平时称呼…

centos连接XShell

先设置网络自动连接&#xff0c;为Xshell 连接centos做准备 选择应用程序->系统工具->设置 选择网络&#xff0c;如果有线没有打开&#xff0c;选择打开&#xff0c;在点击设置 记住ipv4地址&#xff0c;选择自动连接&#xff0c;然后应用 最后鼠标右键点击桌面&#xf…

RabbitMQ入门案例之Topic模式

前言&#xff1a; 本文章将介绍RabbitMQ中的Topic&#xff08;主题&#xff09;模式&#xff0c;其中还会涉及 ‘#’ 和 ‘*’ 两个通配符在RabbitMQ中的区别。 官网文档地址&#xff1a;https://rabbitmq.com/getstarted.html 什么是Topic模式 RabbitMQ的Topic模式是一种基于…

SpringBoot 如何使用 Spring Integration 处理事件

SpringBoot 如何使用 Spring Integration 处理事件 Spring Integration 是 Spring Framework 的一个扩展&#xff0c;它提供了一种基于消息传递的集成模式。使用 Spring Integration&#xff0c;我们可以将不同的应用程序、系统和服务连接起来&#xff0c;从而实现数据的传递、…

VMware中Linux虚拟机配置静态ip

一、输入ip addr查看ip地址 二、输入cd /etc/sysconfig/network-scripts进入centos网络配置文件夹 三、接着输入ls查看目录 四、 输入vi ifcfg-ens33进入网卡配置 五、 进入以后是这个界面&#xff0c;红色方框里的内容是需要手动修改的&#xff0c;下面图片里已经修改过了。 …

【C】分支和循环语句的简单介绍

语句 分支语句if语句语法结构代码演示 switch语句语法结构代码演示 循环语句while循环语法结构代码分析 for循环语法结构代码演示 do...while循环语法结构代码分析 什么是语句呢&#xff1f; 在C语言中由分号&#xff08;;&#xff09;隔开的就是一条语句。 分支语句 if语句 …