亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

Map 使用 Lambda 的 forEach 實(shí)現(xiàn)跳出循環(huán)操作

 更新時(shí)間:2020年09月14日 09:12:57   作者:有一個(gè)人  
這篇文章主要介紹了Map 使用 Lambda 的 forEach 實(shí)現(xiàn)跳出循環(huán)操作,具有很好的參考價(jià)值,希望對大家有所幫助。一起跟隨小編過來看看吧

Lambda 的 forEach表達(dá)式用起來很爽啊,最近開發(fā)中用來遍歷了一下Map,結(jié)果就翻車了......大致場景如下:

public static void main(String[] args) {
  HashMap<String,String> map = new HashMap<>();
  map.put("1","001");
  map.put("2","002");
  map.put("3","003");
  map.put("4","004");
  map.put("5","005");
  map.forEach((k,v)->{
    if (v.contains("3")){
      System.out.println("找到你了呦......");
      return;
    }
    System.out.println(v);
  });

本來是要在找到包含了"3"的值之后終止循環(huán)的,結(jié)果break 編譯錯(cuò)誤.只好用return試試,神奇的事情發(fā)生了,并沒有跳出循環(huán),return在這里起到了continue的效果.為什么呢? --- 因?yàn)?)->{}其實(shí)是匿名內(nèi)部類,匿名內(nèi)部類如何能使用break和continue呢,當(dāng)然編譯錯(cuò)誤啊.在匿名內(nèi)部類里面return了也僅僅是匿名內(nèi)部類的調(diào)用終止,for循環(huán)繼續(xù)下一次循環(huán)而已.所以,無奈之下,只能曲線救國了---使用

anyMatch

boolean result = map.entrySet().stream().anyMatch(e -> e.getValue().contains("3"));
if (result){
  System.out.println("找到你了呦......");
}

補(bǔ)充知識(shí):java8 lambda forEach循環(huán)與增強(qiáng)for循環(huán)性能對比

最近新的項(xiàng)目使用jdk1.8版本,于是乎博主想多使用一些lambda的寫法,但是對于lambda并不是很了解所以在網(wǎng)上查了一些性能方面的資料,結(jié)果瞬間心涼,多數(shù)回答為lambda forEach循環(huán)性能要比傳統(tǒng)循環(huán)差,性能甚至差出十幾倍。然而,經(jīng)過博主的測試那些回答是錯(cuò)誤的。

性能對比的結(jié)論為 lambda forEach>增強(qiáng)for,以下給出測試數(shù)據(jù)。

public static void main(String[] args) {
    test1();
  }

  public static void test1() {
    List<User> userList = initList(10000);
    for (int i = 1; i < 11; i++) {
      System.out.println("--------------------第" + i + "次");
      long t1 = System.nanoTime();
      testLambda(userList);
      long t2 = System.nanoTime();
      testForeach(userList);
      long t3 = System.nanoTime();
      System.out.println("lambda---" + (t2 - t1) / 1000 + "μs");
      System.out.println("增強(qiáng)for--" + (t3 - t2) / 1000 + "μs");
    }
  }

  public static void test2() {
    List<User> userList = initList(10000);
    long t1 = System.nanoTime();
    testLambda(userList);
    long t2 = System.nanoTime();
    testForeach(userList);
    long t3 = System.nanoTime();
    testLambda1(userList);
    long t4 = System.nanoTime();
    System.out.println("lambda---" + (t2 - t1) / 1000 + "μs");
    System.out.println("增強(qiáng)for--" + (t3 - t2) / 1000 + "μs");
    System.out.println("lambda1---" + (t4 - t3) / 1000 + "μs");
  }

  /**
   * 增強(qiáng)for測試
   *
   * @param userList
   */
  private static void testForeach(List<User> userList) {
    for (User user : userList) {
      user.hashCode();
    }
  }

  /**
   * lambda forEach測試
   *
   * @param userList
   */
  private static void testLambda(List<User> userList) {
    userList.forEach(user -> user.hashCode());
  }

  private static void testLambda1(List<User> userList) {
    userList.forEach(user -> user.hashCode());
  }

  /**
   * 初始化測試集合
   *
   * @param size
   * @return
   */
  private static List<User> initList(int size) {
    List<User> userList = new ArrayList<>();
    for (int i = 0; i < size; i++) {
      userList.add(new User());
    }
    return userList;
  }

測試結(jié)果:

為了驗(yàn)證前面的lomda表達(dá)式對后面的lomda表達(dá)式的影響,將main方法中的test1改為test2測試。

測試結(jié)果:

綜上所述此時(shí)可以看出在第一次的時(shí)候兩者性能相差40倍,這可能也是多數(shù)人認(rèn)為它性能較差的原因,但是再后面的執(zhí)行當(dāng)中幾乎都是lambda的執(zhí)行速度快,所以博主覺得,lambda的forEach循環(huán)在首次執(zhí)行的時(shí)候會(huì)初始化部分內(nèi)容,從而導(dǎo)致執(zhí)行過慢,在后續(xù)的執(zhí)行當(dāng)中由于不需要再次進(jìn)行初始化,所以才展現(xiàn)出真正的實(shí)力。

因 此 博 主 推 薦 將 l a m b d a 表 達(dá) 式 的 初 始 化 放 到 項(xiàng) 目 啟 動(dòng) 的 過 程 中 , 這 樣 可 以 大 大 提 高 l a m b d a 表 達(dá) 式 的 性 能 。

\color{#FF0000}{因此博主推薦將lambda表達(dá)式的初始化放到項(xiàng)目啟動(dòng)的過程中,這樣可以大大提高lambda表達(dá)式的性能。}因此博主推薦將lambda表達(dá)式的初始化放到項(xiàng)目啟動(dòng)的過程中,這樣可以大大提高lambda表達(dá)式的性能。

關(guān)于其他方面的測試,有興趣的同學(xué)可以自行測試。

以上這篇Map 使用 Lambda 的 forEach 實(shí)現(xiàn)跳出循環(huán)操作就是小編分享給大家的全部內(nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持腳本之家。

相關(guān)文章

  • Java使用Lambda表達(dá)式查找list集合中是否包含某值問題

    Java使用Lambda表達(dá)式查找list集合中是否包含某值問題

    Java使用Lambda表達(dá)式查找list集合中是否包含某值的問題,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2023-06-06
  • Kotlin 基礎(chǔ)教程之泛型

    Kotlin 基礎(chǔ)教程之泛型

    這篇文章主要介紹了Kotlin 基礎(chǔ)教程之泛型的相關(guān)資料,需要的朋友可以參考下
    2017-06-06
  • 基于Spring Boot應(yīng)用ApplicationEvent案例場景

    基于Spring Boot應(yīng)用ApplicationEvent案例場景

    這篇文章主要介紹了基于Spring Boot應(yīng)用ApplicationEvent,利用Spring的機(jī)制發(fā)布ApplicationEvent和監(jiān)聽ApplicationEvent,需要的朋友可以參考下
    2023-03-03
  • SpringBoot中異步調(diào)用時(shí)的注意事項(xiàng)

    SpringBoot中異步調(diào)用時(shí)的注意事項(xiàng)

    這篇文章主要介紹了SpringBoot中異步調(diào)用時(shí)的注意事項(xiàng),調(diào)用的異步方法,不能為同一個(gè)類的方法(包括同一個(gè)類的內(nèi)部類),簡單來說,因?yàn)镾pring在啟動(dòng)掃描時(shí)會(huì)為其創(chuàng)建一個(gè)代理類,而同類調(diào)用時(shí),還是調(diào)用本身的代理類的,所以和平常調(diào)用是一樣的,需要的朋友可以參考下
    2023-11-11
  • Java Web項(xiàng)目中編寫定時(shí)任務(wù)的實(shí)現(xiàn)

    Java Web項(xiàng)目中編寫定時(shí)任務(wù)的實(shí)現(xiàn)

    本篇文章主要介紹了Java Web項(xiàng)目中編寫定時(shí)任務(wù)的實(shí)現(xiàn),具有一定的參考價(jià)值,有興趣的可以了解一下。
    2017-01-01
  • java的Jackson將json字符串轉(zhuǎn)換成泛型List

    java的Jackson將json字符串轉(zhuǎn)換成泛型List

    這篇文章主要介紹了java的Jackson將json字符串轉(zhuǎn)換成泛型List ,這里整理了詳細(xì)的代碼,有需要的小伙伴可以參考下。
    2017-02-02
  • Springboot 整合 Java DL4J 實(shí)現(xiàn)農(nóng)產(chǎn)品質(zhì)量檢測系統(tǒng)(推薦)

    Springboot 整合 Java DL4J 實(shí)現(xiàn)農(nóng)產(chǎn)品質(zhì)量檢測系統(tǒng)(推薦)

    本文詳細(xì)介紹了系統(tǒng)的搭建過程,包括技術(shù)選型、數(shù)據(jù)處理、模型訓(xùn)練和評估等關(guān)鍵步驟,系統(tǒng)采用卷積神經(jīng)網(wǎng)絡(luò),對水果成熟度和缺陷進(jìn)行識(shí)別,有效解決了傳統(tǒng)方法成本高、效率低的問題,有助于提升農(nóng)產(chǎn)品檢測的科技含量和自動(dòng)化水平
    2024-10-10
  • springboot+mybatis配置clickhouse實(shí)現(xiàn)插入查詢功能

    springboot+mybatis配置clickhouse實(shí)現(xiàn)插入查詢功能

    這篇文章主要介紹了springboot+mybatis配置clickhouse實(shí)現(xiàn)插入查詢功能,本文通過實(shí)例代碼給大家介紹的非常詳細(xì),對大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2020-08-08
  • 一文搞懂Spring中的JavaConfig

    一文搞懂Spring中的JavaConfig

    這篇文章主要介紹了Spring中的JavaConfig知識(shí),包括事務(wù)注解驅(qū)動(dòng),properties配置文件加載方法,本文給大家介紹的非常詳細(xì),需要的朋友可以參考下
    2021-09-09
  • IDEA .iml文件及.idea文件夾超詳細(xì)講解

    IDEA .iml文件及.idea文件夾超詳細(xì)講解

    iml文件是IntelliJ IDEA自己創(chuàng)建的模塊文件,用于java應(yīng)用開發(fā),存儲(chǔ)一些模塊相關(guān)的信息,比如一個(gè)Java組建,插件組建,Maven組建等,這篇文章主要介紹了IDEA .iml文件及.idea文件夾,需要的朋友可以參考下
    2023-09-09

最新評論