Java中5种List的去重方法及它们的效率对比,你用对了吗?

简介: 01、使用两个for循环实现List去重(有序)/**使用两个for循环实现List去重(有序) * * @param list * */ public static List removeDuplicationBy2For(List<Integer> list) { for (int i=0;i<list.size();i++) { for (int j=i+1;j<list.size();j++) { if(list.get(i).equa

image.png

01、使用两个for循环实现List去重(有序)

/**使用两个for循环实现List去重(有序)
    *
    * @param list
    * */
   public static List removeDuplicationBy2For(List<Integer> list) {
       for (int i=0;i<list.size();i++)
       {
           for (int j=i+1;j<list.size();j++)
           {
               if(list.get(i).equals(list.get(j))){
                   list.remove(j);
               }
           }
       }
       return list;
   }

02、使用List集合contains方法循环遍历(有序)

/**使用List集合contains方法循环遍历(有序)
  *
  * @param list
  * */
 public static List removeDuplicationByContains(List<Integer> list) {
     List<Integer> newList =new ArrayList<>();
     for (int i=0;i<list.size();i++)
     {
         boolean isContains =newList.contains(list.get(i));
         if(!isContains){
             newList.add(list.get(i));
         }
     }
     list.clear();
     list.addAll(newList);
     return list;
 }

03、使用HashSet实现List去重(无序)

/**使用HashSet实现List去重(无序)
   *
   * @param list
   * */
  public static List removeDuplicationByHashSet(List<Integer> list) {
      HashSet set = new HashSet(list);
      //把List集合所有元素清空
      list.clear();
      //把HashSet对象添加至List集合
      list.addAll(set);
      return list;
  }

04、使用TreeSet实现List去重(有序)

/**使用TreeSet实现List去重(有序)
   *
   * @param list
   * */
  public static List removeDuplicationByTreeSet(List<Integer> list) {
      TreeSet set = new TreeSet(list);
      //把List集合所有元素清空
      list.clear();
      //把HashSet对象添加至List集合
      list.addAll(set);
      return list;
  }

05、使用java8新特性stream实现List去重(有序)

/**使用java8新特性stream实现List去重(有序)
   *
   * @param list
   * */
  public static List removeDuplicationByStream(List<Integer> list) {
      List newList = list.stream().distinct().collect(Collectors.toList());
      return newList;
  }

效率测试代码

public static void main(String args[]) {
       List<Integer> list1 = new ArrayList<>();
       List<Integer> list2 = new ArrayList<>();
       List<Integer> list3 = new ArrayList<>();
       List<Integer> list4 = new ArrayList<>();
       List<Integer> list5 = new ArrayList<>();
       Random random =new Random();
       for (int i = 0; i < 100000; i++) {
           int value =random.nextInt(500);
           list1.add(value);
           list2.add(value);
           list3.add(value);
           list4.add(value);
           list5.add(value);
       }
       long startTime ;
       long endTime;
       startTime = System.currentTimeMillis();
       removeDuplicationByHashSet(list1);
       endTime = System.currentTimeMillis();
       System.out.println("使用HashSet实现List去重时间:"+(endTime-startTime)+"毫秒");
       startTime = System.currentTimeMillis();
       removeDuplicationByTreeSet(list2);
       endTime = System.currentTimeMillis();
       System.out.println("使用TreeSet实现List去重时间:"+(endTime-startTime)+"毫秒");
       startTime = System.currentTimeMillis();
       removeDuplicationByStream(list3);
       endTime = System.currentTimeMillis();
       System.out.println("使用java8新特性stream实现List去重:"+(endTime-startTime)+"毫秒");
       startTime = System.currentTimeMillis();
       removeDuplicationBy2For(list4);
       endTime = System.currentTimeMillis();
       System.out.println("使用两个for循环实现List去重:"+(endTime-startTime)+"毫秒");
       startTime = System.currentTimeMillis();
       removeDuplicationByContains(list5);
       endTime = System.currentTimeMillis();
       System.out.println("使用List集合contains方法循环遍历:"+(endTime-startTime)+"毫秒");

   }

结果:

使用HashSet实现List去重时间:40毫秒

使用TreeSet实现List去重时间:36毫秒

使用java8新特性stream实现List去重:78毫秒

使用两个for循环实现List去重:533毫秒

使用List集合contains方法循环遍历:40毫秒

更多测试结果

随机数在100范围内:

使用HashSet实现List去重时间:32毫秒

使用TreeSet实现List去重时间:40毫秒

使用java8新特性stream实现List去重:128毫秒

使用两个for循环实现List去重:693毫秒

使用List集合contains方法循环遍历:30毫秒

随机数在1000范围内:

使用HashSet实现List去重时间:34毫秒

使用TreeSet实现List去重时间:72毫秒

使用java8新特性stream实现List去重:125毫秒

使用两个for循环实现List去重:1063毫秒

使用List集合contains方法循环遍历:85毫秒

随机数在10000范围内:

使用HashSet实现List去重时间:51毫秒

使用TreeSet实现List去重时间:103毫秒

使用java8新特性stream实现List去重:201毫秒

使用两个for循环实现List去重:5448毫秒

使用List集合contains方法循环遍历:791毫秒

结论
无序HashSet,有序TreeSet

Java 的知识面非常广,面试问的涉及也非常广泛,重点包括:Java 基础、Java 并发,JVM、MySQL、数据结构、算法、Spring、微服务、MQ 等等,涉及的知识点何其庞大,所以我们在复习的时候也往往无从下手,今天小编给大家带来一套 Java 面试题,题库非常全面,包括 Java 基础、Java 集合、JVM、Java 并发、Spring全家桶、Redis、MySQL、Dubbo、Netty、MQ 等等,包含 Java 后端知识点 2000 +

资料获取方式:关注公种浩:“程序员白楠楠”获取上述资料

相关文章
|
2月前
|
消息中间件 Java Kafka
在Java中实现分布式事务的常用框架和方法
总之,选择合适的分布式事务框架和方法需要综合考虑业务需求、性能、复杂度等因素。不同的框架和方法都有其特点和适用场景,需要根据具体情况进行评估和选择。同时,随着技术的不断发展,分布式事务的解决方案也在不断更新和完善,以更好地满足业务的需求。你还可以进一步深入研究和了解这些框架和方法,以便在实际应用中更好地实现分布式事务管理。
|
2月前
|
Java
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
java小工具util系列5:java文件相关操作工具,包括读取服务器路径下文件,删除文件及子文件,删除文件夹等方法
101 9
|
3天前
|
存储 Java 索引
Java快速入门之数组、方法
### Java快速入门之数组与方法简介 #### 一、数组 数组是一种容器,用于存储同种数据类型的多个值。定义数组时需指定数据类型,如`int[]`只能存储整数。数组的初始化分为静态和动态两种: - **静态初始化**:直接指定元素,系统自动计算长度,如`int[] arr = {1, 2, 3};` - **动态初始化**:手动指定长度,系统给定默认值,如`int[] arr = new int[3];` 数组访问通过索引完成,索引从0开始,最大索引为`数组.length - 1`。遍历数组常用`for`循环。常见操作包括求和、找最值、统计特定条件元素等。
|
1天前
|
算法 Java API
Java 方法注释:规范、实用和高质量的写法
本文深入探讨了如何编写高质量的 Java 方法注释
22 11
|
1天前
|
SQL Java 数据库连接
【潜意识Java】Java中JDBC过时方法的替代方案以及JDBC为什么过时详细分析
本文介绍了JDBC中一些常见过时方法及其替代方案。
20 5
|
1月前
|
Java 机器人 程序员
从入门到精通:五种 List 遍历方法对比与实战指南
小米是一位热爱分享技术的程序员,本文详细介绍了 Java 中遍历 List 的五种方式:经典 for 循环、增强 for 循环、Iterator 和 ListIterator、Stream API 以及 forEach 方法。每种方式都有其适用场景和优缺点,例如 for 循环适合频繁访问索引,增强 for 循环和 forEach 方法代码简洁,Stream API 适合大数据量操作,ListIterator 支持双向遍历。文章通过生动的小故事和代码示例,帮助读者更好地理解和选择合适的遍历方式。
63 2
|
2月前
|
安全 Java 开发者
Java中WAIT和NOTIFY方法必须在同步块中调用的原因
在Java多线程编程中,`wait()`和`notify()`方法是实现线程间协作的关键。这两个方法必须在同步块或同步方法中调用,这一要求背后有着深刻的原因。本文将深入探讨为什么`wait()`和`notify()`方法必须在同步块中调用,以及这一机制如何确保线程安全和避免死锁。
60 4
|
2月前
|
Java
深入探讨Java中的中断机制:INTERRUPTED和ISINTERRUPTED方法详解
在Java多线程编程中,中断机制是协调线程行为的重要手段。了解和正确使用中断机制对于编写高效、可靠的并发程序至关重要。本文将深入探讨Java中的`Thread.interrupted()`和`Thread.isInterrupted()`方法的区别及其应用场景。
84 4
|
2月前
|
Java 数据处理 数据安全/隐私保护
Java处理数据接口方法
Java处理数据接口方法
32 1
|
2月前
|
存储 Java 程序员
Java基础的灵魂——Object类方法详解(社招面试不踩坑)
本文介绍了Java中`Object`类的几个重要方法,包括`toString`、`equals`、`hashCode`、`finalize`、`clone`、`getClass`、`notify`和`wait`。这些方法是面试中的常考点,掌握它们有助于理解Java对象的行为和实现多线程编程。作者通过具体示例和应用场景,详细解析了每个方法的作用和重写技巧,帮助读者更好地应对面试和技术开发。
149 4