欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java求兩集合中元素交集的四種方法對(duì)比分析

 更新時(shí)間:2023年05月29日 14:45:43   作者:java技術(shù)媛  
這篇文章主要介紹了Java求兩集合中元素交集的四種方法對(duì)比總結(jié),四種求集合中元素交集的方法,按照在處理大量數(shù)據(jù)的效率來(lái)看,使用map集合的特性的方法效率最高,之后是使用Java流的方法,其次是使用for循環(huán)和迭代器的方法,需要的朋友可以參考下

最近在做項(xiàng)目的時(shí)候有用到對(duì)兩個(gè)集合中的元素進(jìn)行對(duì)比求其交集的情況,因?yàn)樯婕暗降臄?shù)據(jù)量比較大,所以在進(jìn)行求兩個(gè)集合中元素交集的時(shí)候,就應(yīng)該考慮到程序運(yùn)行的時(shí)間消耗等問(wèn)題,

所以寫了四種求集合元素交集的方法 今天這篇文章主要是來(lái)記錄對(duì)比一下,這四種方法使用起來(lái)的效率問(wèn)題,

方法一,求兩個(gè)集合的交集【普通for循環(huán)】

這種方法是最普通的進(jìn)行for循環(huán)比較的方法。利用集合的contains方法,來(lái)對(duì)比第二個(gè)集合中是否存在相同的元素的方法,同時(shí)將交集結(jié)果返回。

代碼示例如下:

/**
    * 方法1,求兩個(gè)集合的交集
    *
    * @param arr1
    * @param arr2
    * @return
    */
   public List<Object> intersectionForList_1(List<Object> arr1, List<Object> arr2) {
       long startTime = System.currentTimeMillis();
       List<Object> result = new ArrayList<>();
       for (Object arr : arr1) {
           if (arr2.contains(arr)) {
               result.add(arr);
           }
       }
       long endTime = System.currentTimeMillis();
       log.info("intersectionForList_1:" + (endTime - startTime));
       return result;
   }

方法二,求兩個(gè)集合交集,(迭代器)

這種方法使用的是list集合的迭代器的方法,其實(shí)原理和for是一樣的,方法的核心也和for循環(huán)是一樣的,只是外層循環(huán)的方法不一樣,所以它和上面第一種方法的效果是一樣的。

代碼示例如下:

 
  /**
   * 方法2,求兩個(gè)集合交集,(迭代器)
   *
   * @param arr1
   * @param arr2
   * @return
   */
  public List<Object> intersectionForList_2(List<Object> arr1, List<Object> arr2) {
      long startTime = System.currentTimeMillis();
      List<Object> resultList = new ArrayList<>();
      List<Object> maxList;
      List<Object> minList;
      if (arr1.size()>arr2.size()){
          maxList = arr1;
          minList = arr2;
      }else {
          maxList = arr2;
          minList = arr1;
      }
      Iterator<Object> iterator = maxList.iterator();
      while (iterator.hasNext()){
          Object next = iterator.next();
          if (minList.contains(next)){
              resultList.add(next);
          }
      }
      long endTime = System.currentTimeMillis();
      log.info("intersectionForList_2:" + (endTime - startTime));
      return resultList;
  }

方法三,求兩個(gè)集合交集,(map)

這種方法使用的是map的特性,首先將list集合中的元素依次存入一個(gè)map中去,然后再以map的get方法來(lái)判斷是否存在這樣的元素。

這種方法的效率最高,在10萬(wàn)條數(shù)據(jù)的測(cè)試下,這種方法耗時(shí)僅僅在十幾毫秒,而其他方法在將近一百多毫秒。

在百萬(wàn)條數(shù)據(jù)進(jìn)行對(duì)比處理的時(shí)候,使用map特性的方法時(shí)間消耗大概在40毫秒左右,但是其他方法要將近10秒鐘,

所以在對(duì)于大量數(shù)據(jù)的處理過(guò)程中,還是非常建議使用這種方法的。

代碼示例如下:

    /**
     * 方法3,求兩個(gè)集合交集,(map)
     *
     * @param arr1
     * @param arr2
     * @return
     */
    public List<Object> intersectionForList_3(List<Object> arr1, List<Object> arr2) {
        long startTime = System.currentTimeMillis();
        List<Object> resultList = new ArrayList<>();
        Map<String,Object> map = new HashMap<>();
        arr1.forEach(a1->{
            map.put(a1+"",a1);
        });
        arr2.forEach(a2->{
            Object obj = map.get(a2 + "");
            if (obj!=null){
                resultList.add(obj);
            }
        });
        long endTime = System.currentTimeMillis();
        log.info("intersectionForList_3:" + (endTime-startTime));
        return resultList;
    }

方法四,求兩個(gè)集合交集,(forEasy)

這種方法使用的是集合的foreasy特性和Java流的特性,使用這種方法可以遍歷其中的一個(gè)集合,然后再使用contains方法來(lái)判斷另一個(gè)集合中是否存在該集合元素,這種方法的使用效率要優(yōu)于第一種和第二種方法。

代碼示例如下:

    /**
     * 方法4,求兩個(gè)集合交集,(forEasy)
     * @param arr1
     * @param arr2
     * @return
     */
    public List<Object> intersectionForList_4(List<Object> arr1, List<Object> arr2){
        long startTime = System.currentTimeMillis();
        List<Object> resultList = new ArrayList<>();
        arr1.stream().forEach(a1->{
            if (arr2.contains(a1)){
                resultList.add(a1);
            }
        });
        long endTime = System.currentTimeMillis();
        log.info("intersectionForList_4:" + (endTime-startTime));
        return resultList;
    }

方法總結(jié)

總結(jié)一下以上四種求集合中元素交集的方法,按照在處理大量數(shù)據(jù)的效率來(lái)看,使用map集合的特性的方法效率最高,之后是使用Java流的方法,其次是使用for循環(huán)和迭代器的方法,所以在正常情況下,還是推薦使用map的特性來(lái)進(jìn)行集合中元素的對(duì)比分析和求交集的。

到此這篇關(guān)于Java求兩集合中元素交集的四種方法對(duì)比總結(jié)的文章就介紹到這了,更多相關(guān)java求兩集合中元素交集內(nèi)容請(qǐng)搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • 128進(jìn)制加密數(shù)據(jù)示例分享

    128進(jìn)制加密數(shù)據(jù)示例分享

    這篇文章主要介紹了128進(jìn)制加密數(shù)據(jù)示例,這里使用JAVA實(shí)現(xiàn),需要的朋友可以參考下
    2014-03-03
  • Java實(shí)現(xiàn)批量下載(打包成zip)的實(shí)現(xiàn)

    Java實(shí)現(xiàn)批量下載(打包成zip)的實(shí)現(xiàn)

    這篇文章主要介紹了Java實(shí)現(xiàn)批量下載(打包成zip)的實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2020-11-11
  • SpringBoot訪問(wèn)windows共享文件的方法

    SpringBoot訪問(wèn)windows共享文件的方法

    這篇文章主要介紹了SpringBoot訪問(wèn)windows共享文件,項(xiàng)目使用minio存儲(chǔ)且不在同一臺(tái)服務(wù)器上,為了優(yōu)化速度決定使用windows共享功能進(jìn)行文件傳輸,本文結(jié)合實(shí)例代碼給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2023-02-02
  • Schedule定時(shí)任務(wù)在分布式產(chǎn)生的問(wèn)題詳解

    Schedule定時(shí)任務(wù)在分布式產(chǎn)生的問(wèn)題詳解

    這篇文章主要介紹了Schedule定時(shí)任務(wù)在分布式產(chǎn)生的問(wèn)題詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2022-10-10
  • SpringSecurity集成第三方登錄過(guò)程詳解(最新推薦)

    SpringSecurity集成第三方登錄過(guò)程詳解(最新推薦)

    在ThirdAuthenticationFilter 類的attemptAuthentication()方法中,我們通過(guò)authType類型,然后創(chuàng)建對(duì)應(yīng)的Authentication實(shí)現(xiàn)來(lái)實(shí)現(xiàn)不同方式的登錄,下面給大家分享SpringSecurity集成第三方登錄過(guò)程,感興趣的朋友一起看看吧
    2024-05-05
  • 徹底搞定堆排序:二叉堆

    徹底搞定堆排序:二叉堆

    二叉堆有兩種:最大堆和最小堆。最大堆:父結(jié)點(diǎn)的鍵值總是大于或等于任何一個(gè)子節(jié)點(diǎn)的鍵值;最小堆:父結(jié)點(diǎn)的鍵值總是小于或等于任何一個(gè)子節(jié)點(diǎn)的鍵值
    2021-07-07
  • SpringBoot整合Mybatis?LocalDateTime?映射失效的解決

    SpringBoot整合Mybatis?LocalDateTime?映射失效的解決

    這篇文章主要介紹了SpringBoot整合Mybatis?LocalDateTime?映射失效的解決方案,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 用Maven插件生成Mybatis代碼的實(shí)現(xiàn)方法

    用Maven插件生成Mybatis代碼的實(shí)現(xiàn)方法

    本文主要介紹 Maven插件生成Mybatis代碼,現(xiàn)在做開(kāi)發(fā)的朋友有好多用Maven 來(lái)管理代碼,這里給大家舉個(gè)例子,有需要的同學(xué)可以看下
    2016-07-07
  • mybatisplus如何在xml的連表查詢中使用queryWrapper

    mybatisplus如何在xml的連表查詢中使用queryWrapper

    這篇文章主要介紹了mybatisplus如何在xml的連表查詢中使用queryWrapper,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • mybatis中sql語(yǔ)句CDATA標(biāo)簽的用法說(shuō)明

    mybatis中sql語(yǔ)句CDATA標(biāo)簽的用法說(shuō)明

    這篇文章主要介紹了mybatis中sql語(yǔ)句CDATA標(biāo)簽的用法說(shuō)明,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2021-06-06

最新評(píng)論