时间:2021-05-19
遍历Collection的代码,可以是采用Iterator接口,通过next()遍历。如:
List<String> list = Arrays.asList("Hi", "I", "am", "Henry.Yao"); // 此处已经用到了泛型,不能算是纯粹的Java2代码,仅作Iterator示范 for (Iterator<String> it = list.iterator(); it.hasNext();) { String item = it.next(); System.out.println("listItem = " + item); }输出:
listItem = Hi
listItem = I
listItem = am
listItem = Henry.Yao
在Java5中,提供了增强的for循环,如:
List<String> list = Arrays.asList("Hi", "I", "am", "Henry.Yao"); for(String item : list) { System.out.println("listItem = " + item); }在Java8中,通过Lambda表达式提供了更简洁的编程方式,如:
list.forEach(item -> { System.out.println("listItem = " + item); });操作集合元素item的同时,如果还需要同时提供index值,咋办?
思考后,我们可能大都写出了如下的代码,同时心有不甘:
输出:
list[0] = Hi,
list[1] = I
list[2] = am
list[3] = Henry.Yao
因为,如下的模式才是我们期望的模式
list.forEach((item, index) -> { System.out.println("listItem = " + item); }); // Compile ERROR这只是期望。实际上,Jdk8并没有提供该函数,直至Jdk11也均没有提供该函数。
“没有工具,我们制造工具” 定义如下的工具方法,基于这个工具方法,我们就能在遍历集合,同时提供item和index值:
// 工具方法 public static <T> Consumer<T> consumerWithIndex(BiConsumer<T, Integer> consumer) { class Obj { int i; } Obj obj = new Obj(); return t -> { int index = obj.i++; consumer.accept(t, index); }; }这样的业务代码,是我期望的!
基于该工具方法,便可轻松编写如下业务代码,清晰、简洁:
list.forEach(LambdaUtils.consumerWithIndex((item, index) -> { System.out.println("list[" + index + "]=" + item); }));这个工具方法的设计过程,也是参考借鉴了distinctByKey,如图:
// 工具方法 public static <T> Predicate<T> distinctByKey(Function<? super T, ?> keyExtractor) { Map<Object, Boolean> seen = new ConcurrentHashMap<>(); return t -> Objects.isNull(seen.putIfAbsent(keyExtractor.apply(t), Boolean.TRUE)); } // 业务代码 // 从人员列表中过滤出一个子集(每个部门选一个人) employees.stream().filter(distinctByKey(Employee::getDeptCode)).collect(toList());我们的程序,不仅仅只是大片的业务代码,更是需要抽象和提取出的诸多工具方法。
使用工具(使用Java和第三方提供的方法)到极致,那是高级程序员,
制造工具(分析和设计出项目的工具方法)到极致,那是高级设计师。
到此这篇关于详解Java8的forEach(...)如何提供index值的文章就介绍到这了,更多相关Java8 forEach提供index值内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
LocalDate、LocalTime、LocalDateTime是Java8开始提供的时间日期API,主要用来优化Java8以前对于时间日期的处理操作。然而,
Java8新特性内建函数式接口 在之前的一片博文Lambda表达式,提到过Java8提供的函数式接口。在此文中,将介绍一下Java8四个最基本的函数式接口
在这个页面上我们将提供java8Streamsorted()示例。我们可以按照自然排序以及Comparator提供的排序对流进行排序。在java8中Compar
前言在Java8之前,默认情况下,接口中的所有方法都是公共的和抽象的。但是这一限制在Java8中被打破了,Java8允许开发人员在接口中添加新方法,而无需在实现
前言最近在学习java8,所以接下来会给大家介绍一系列的Java8学习内容,那么让我们先从lambda表达式开始。众所周知从java8出现以来lambda是最重