一:函数对象定义
函数对象做了这么一件事,我们可以定义一个只有方法而没有数据的类,然后把这个类的对象传递给别的方法,这时传递的这个对象就是一个函数对象。
说起这个函数对象,其实存在那么一种设计模式,叫做策略模式,其主体就是函数对象的应用。
为什么会出现函数对象这种形式呢?很简单,如果我们要比较一些元素,那么我们一般会在这些元素的类型定义上是想Comparable接口,但是现实情况往往比我们想想的复杂的多,可能实现这个接口并不能满足我们的比较接口,这个时候我们就把比较规则封装到一个函数对象中,然后把需要比较的数据元素和这个比较函数对象一块传递给业务函数。
许多集合类API的类和程序需要有给对象排序的能力,有两种方法可以实现。
一种方法是对象实现了Comparable接口,并提供一个compareTo方法;
另一种方法是在一个实现了Comparator接口的对象中嵌入一个作为compare方法的比较函数。
看下面一个例子:
import java.util.Comparator;
/**
* @author lihe
* 问题:找出一个字符串数组中,长度最长的字符串
*/
class FindMaxString implements Comparator<String> {
@Override
public int compare(String o1, String o2) {
return o1.length() - o2.length();
}
}
public class TestString{
public static void main(String[] args) {
String[] str = {"defadg","dfegagrh","dfec"};
System.out.println(maxLength(str, new FindMaxlength()));
}
/**
* 这是一个真正的泛型方法。
* 首先在public与返回值之间的<T>必不可少,这表明这是一个泛型方法,
* 并且声明了一个泛型T,这个T可以出现在这个泛型方法的任意位置.
*/
public static<T> T maxLength(T[]str,Comparator<? super T> com){
int maxIndex = 0;
for (int i = 0; i < str.length; i++) {
if(com.compare(str[i], str[maxIndex]) > 0){
maxIndex = i;
}
}
return str[maxIndex];
}
}