J**a Map的forEach方法是J**a 8中引入的一个新特性,主要用于迭代Map集合中的键值对。函数接受一个BiConsumer函数式接口作为参数,可以对Map集合中的每一个键值对进行操作。 一、forEach方法的基本使用 在J**a 8以前,我们通常使用entrySet配合for-each循环来遍历Map。在J**a...
J**a Map的forEach方法是J**a 8中引入的一个新特性,主要用于迭代Map集合中的键值对。函数接受一个BiConsumer函数式接口作为参数,可以对Map集合中的每一个键值对进行操作。
在J**a 8以前,我们通常使用entrySet配合for-each循环来遍历Map。在J**a 8中,我们可以使用forEach方法,它更简洁,易读。
import j**a.util.Map; import j**a.util.HashMap; public class Main { public static void main(String[] args) { Map<String, Integer> items = new HashMap<>(); items.put("A", 10); items.put("B", 20); items.put("C", 30); items.forEach((k,v)->System.out.println("Item : " + k + " Count : " + v)); } }
forEach方法接受的是一个BiConsumer类型的函数式接口参数,我们可以利用lambda表达式对其进行函数式编程,使得其更具有扩展性和灵活性。
import j**a.util.Map; import j**a.util.HashMap; public class Main { public static void main(String[] args) { Map<String, Integer> items = new HashMap<>(); items.put("A", 10); items.put("B", 20); items.put("C", 30); items.forEach((k,v)->{ System.out.println("Item : " + k + " Count : " + v); if("C".equals(k)) { System.out.println("Hello C"); } }); } }
forEach方法对Map的元素做顺序处理,那如果我们有大量数据需要处理,使用并行流就会更高效。此时,我们可以使用并行Stream与forEach结合进行操作。
import j**a.util.Map; import j**a.util.HashMap; import j**a.util.stream.Collectors; public class Main { public static void main(String[] args) { Map<String, Integer> items = new HashMap<>(); items.put("A", 10); items.put("B", 20); items.put("C", 30); items.entrySet().stream() .parallel() .forEach(entry -> { System.out.println("Item : " + entry.getKey() + " Count : " + entry.getValue()); }); } }