Java 中的高阶函数

Java 中的匿名类,事实上可以理解成一个较笨重的闭包(可执行单元),我们可以通过 Java 的匿名类来实现上述的 map 操作,首先,我们需要一个对函数的抽象:

interface Function{
int execute(int x);
}
问题
我们假设 Function 接口中有一个方法 execute,接受一个整型参数,返回一个整型参数,然后我们在类 List 中,实现 map 操作:

private int[] array;

public List(int[] array){
this.array = array;
}
public void map(Function func){
for(int i = 0, len = this.array.length; i < len; i++){
this.array[i] = func.execute(this.array[i]);
}
}
问题
map 接受一个实现了 Function 接口的类的实例,并调用这个对象上的 execute 方法来处理数组中的每一个元素。我们这里直接修改了私有成员 array,而并没有创建一个新的数组。好了,我们来做个测试:

问题
public static void main(String[] args){
List list = new List(new int[]{1, 2, 3, 4, 5});
list.print();
list.map(new Function(){
Public int execute(int x){
return x * 2;
}
}),
list.print();

list.map(new Function(){
Public int execute(int x){
return x * 3;
}
}),
list.print();
}
问题
同前边的两个例子一样,这个程序会打印:

1 2 3 4 5
2 4 6 8 10
6 12 18 24 30
问题
灰色背景色的部分即为创建一个匿名类,从而实现高阶函数。很明显,我们需要传递给 map 的是一个可以执行 execute 方法的代码。而由于 Java 是命令式的编程语言,函数并非第 一位的,函数必须依赖于对象,附属于对象,因此我们不得不创建一个匿名类来包装这个 execute 方法。而在 JavaScript 中,我们只需要传递函数本身即可,这样完全合法,而且 代码更容易被人理解。

你可能感兴趣的:(JVM)