Map 使用 Lambda 的 forEach 實現跳出迴圈操作
Lambda 的 forEach表示式用起來很爽啊,最近開發中用來遍歷了一下Map,結果就翻車了......大致場景如下:
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"的值之後終止迴圈的,結果break 編譯錯誤.只好用return試試,神奇的事情發生了,並沒有跳出迴圈,return在這裡起到了continue的效果.為什麼呢? --- 因為()->{}其實是匿名內部類,匿名內部類如何能使用break和continue呢,當然編譯錯誤啊.在匿名內部類裡面return了也僅僅是匿名內部類的呼叫終止,for迴圈繼續下一次迴圈而已.所以,無奈之下,只能曲線救國了---使用
anyMatch
boolean result = map.entrySet().stream().anyMatch(e -> e.getValue().contains("3")); if (result){ System.out.println("找到你了呦......"); }
補充知識:java8 lambda forEach迴圈與增強for迴圈效能對比
最近新的專案使用jdk1.8版本,於是乎博主想多使用一些lambda的寫法,但是對於lambda並不是很瞭解所以在網上查了一些效能方面的資料,結果瞬間心涼,多數回答為lambda forEach迴圈效能要比傳統迴圈差,效能甚至差出十幾倍。然而,經過博主的測試那些回答是錯誤的。
效能對比的結論為 lambda forEach>增強for,以下給出測試資料。
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("增強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("增強for--" + (t3 - t2) / 1000 + "μs"); System.out.println("lambda1---" + (t4 - t3) / 1000 + "μs"); } /** * 增強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; }
測試結果:
為了驗證前面的lomda表示式對後面的lomda表示式的影響,將main方法中的test1改為test2測試。
測試結果:
綜上所述此時可以看出在第一次的時候兩者效能相差40倍,這可能也是多數人認為它效能較差的原因,但是再後面的執行當中幾乎都是lambda的執行速度快,所以博主覺得,lambda的forEach迴圈在首次執行的時候會初始化部分內容,從而導致執行過慢,在後續的執行當中由於不需要再次進行初始化,所以才展現出真正的實力。
因 此 博 主 推 薦 將 l a m b d a 表 達 式 的 初 始 化 放 到 項 目 啟 動 的 過 程 中 , 這 樣 可 以 大 大 提 高 l a m b d a 表 達 式 的 性 能 。
\color{#FF0000}{因此博主推薦將lambda表示式的初始化放到專案啟動的過程中,這樣可以大大提高lambda表示式的效能。}因此博主推薦將lambda表示式的初始化放到專案啟動的過程中,這樣可以大大提高lambda表示式的效能。
關於其他方面的測試,有興趣的同學可以自行測試。
以上這篇Map 使用 Lambda 的 forEach 實現跳出迴圈操作就是小編分享給大家的全部內容了,希望能給大家一個參考,也希望大家多多支援我們。