假设你有一篮子食物:
List<Food> basket = List.of( new Food("Apple", FRUIT), new Food("Banana", FRUIT), new Food("Carrot", VEGETABLE), new Food("Orange", FRUIT), );
并且要求仅接受仅装满水果的篮子。为了满足这个要求,您决定实现一个 for 循环:
private boolean containtsOnlyFruits(List<Food> basket) { for (Food food : basket) { if (food.getFoodType() != FRUIT) { return false; } } return true; }
然后,您记得您一直在学习 Java Lambda 和更实用的方法,因此您决定在 forEach lambda 中编写相同的内容:
private boolean containtsOnlyFruits(List<Food> basket) { basket.forEach(food -> { if (food.getFoodType() != FRUIT) { return false; } }); return true; }
只是遇到一个错误:
意外的返回值
这是为什么?
lambda 只不过是一个函数。在这种情况下,是一个匿名函数,或者换句话说,是一个没有名称的函数。就像任何其他函数一样,lambda 可以接收参数并期望返回一些内容。
当你尝试从 forEach lambda 返回 false 时,你实际上是在尝试退出这个匿名函数并输出一个布尔值。但是,forEach 函数预计不会返回任何结果。这根本不是这个功能的实现方式。
事实上,如果你看一下 forEach 函数的实现,你会发现它接受一个 Consumer:
default void forEach(Consumer<? super T> action) { Objects.requireNonNull(action); for (T t : this) { action.accept(t); } }
消费者是一个接口,表示接受单个输入参数且不返回结果的操作。在此实现中,您可以看到在底层,forEach 函数使用 foreach 循环,执行给定的操作并且不返回任何内容。
因此,为了满足函数式方法中的操作,我们需要找到另一个 lambda。这里有一个很好的候选者:allMatch。
使用 allMatch lambda,我们可以检查篮子中的所有元素是否都是水果:
private boolean onlyFruits(List<Food> basket) { return basket.stream().allMatch(food -> food.getFoodType() == FRUIT); }
如果是这样的话,我们的 lambda 将返回 true。如果我们看一下 allMatch 的内部:
boolean allMatch(Predicate<? super T> predicate);
我们将看到 allMatch 函数需要一个谓词。
谓词是一个函数式接口,就像消费者一样,但它的工作方式有点不同。 Consumer 表示接受单个输入参数且不返回结果的操作,而 Predicate 表示一个参数的谓词(布尔值函数),用于测试对象的条件并返回布尔值(true 或 false) ).
还有其他非常重要的功能接口。你能告诉我它们是什么以及它们如何工作吗?
保持好奇心!
写作需要时间和精力。我喜欢写作和分享知识,但我也有账单要付。
如果您喜欢我的作品,请考虑通过“买杯咖啡”捐款:https://www.buymeacoffee.com/RaphaelDeLio
或者发送给我比特币:1HjG7pmghg3Z8RATH4aiUWr156BGafJ6Zw
以上是为什么我的 forEach lambda 不允许我使用 Java 中的 return 语句退出函数?的详细内容。更多信息请关注PHP中文网其他相关文章!