🔍目的
功能模式代表了一种以组合功能为中心的图书馆组织风格。
简单地说,有一些类型 T,一些用于构造类型 T 的“原始”值的函数,以及一些可以以各种方式组合类型 T 的值以构建更复杂的类型 T 值的“组合器”
🔍解释
真实世界例子
在计算机科学中,组合逻辑被用作计算的简化模型,用于可计算性理论和证明理论。 尽管组合逻辑很简单,但它捕获了计算的许多基本特征。
通俗描述
组合器允许从先前定义的“事物”创建新的“事物”。
维基百科
组合器是一个高阶函数,仅使用函数应用程序和之前定义的组合器来定义其参数的结果。
程序实例
创建一个由not ,or ,and ,contains方法组成的接口
// 用于查找文本中的行的功能界面。
public interface Finder {
// 在文本中查找行的函数。
List<String> find(String text);
// 函数{@link #find(String)}的简单实现。
static Finder contains(String word) {
return txt -> Stream.of(txt.split("\n"))
.filter(line -> line.toLowerCase().contains(word.toLowerCase()))
.collect(Collectors.toList());
}
// 组合器:not。
default Finder not(Finder notFinder) {
return txt -> {
List<String> res = this.find(txt);
res.removeAll(notFinder.find(txt));
r