Java 21及更高版本提供了丰富的函数式接口,例如Function、Predicate、Supplier和Consumer,位于java.util.function包中。 然而,过度使用这些接口常常导致代码冗余。
以下示例展示了这种冗余:
private static class ClassMapperFn implements Function<Integer, String> { @Override public String apply(final Integer integer) { return integer.toString(); } }
与之相比,以下代码实现相同的功能,却更加简洁:
private static class ClassMapper { public String apply(final Integer integer) { return integer.toString(); } }
Java能够隐式识别方法作为函数,因此显式实现函数式接口通常是不必要的。
下面是两种方法的应用示例:
显式定义:
final var mapperFn = new ClassMapperFn(); System.out.println(mapperFn.apply(101)); Stream.of(1, 2, 3, 4, 5) .map(mapperFn::apply) .forEach(System.out::println);
隐式定义:
final var mapper = new ClassMapper(); System.out.println(mapper.apply(101)); Stream.of(1, 2, 3, 4, 5) .map(mapper::apply) .forEach(System.out::println);
结果完全一致!显式定义增加了代码复杂度,而没有带来任何实际好处。
此外,IDE 的代码分析功能也能帮助我们更高效地追踪代码使用情况。例如,在 IntelliJ IDEA 中,使用快捷键 Ctrl+鼠标左键或 Alt+F7,可以快速查找方法或变量的引用。 直接使用普通方法(非函数式接口实现)时,IDE 能更精准地定位到项目内的调用,而使用函数式接口实现时,则会包含依赖库中的调用,这可能会干扰代码分析。 因此,除非有特殊需求,否则建议优先选择更简洁的普通方法。
以上就是函数式接口:避免这种使用!的详细内容,更多请关注知识资源分享宝库其它相关文章!
版权声明
本站内容来源于互联网搬运,
仅限用于小范围内传播学习,请在下载后24小时内删除,
如果有侵权内容、不妥之处,请第一时间联系我们删除。敬请谅解!
E-mail:dpw1001@163.com
发表评论