注:在您阅读本篇的时候,希望你对java generic(范型)能够有所了解和明白。
记:周末在给javaparty讲fp中,很多人似乎对fp并不关心,也认为java中fp的作用不大。其实这是个很大的观念错误,范型的发展,对java的函数式编程支持很大,对functor的影响也非常大。functor在算法、逻辑、条件计算、规则引擎等等方面,都会有很大的作为,这个影响可就会深远的多了。―― 估且以此篇的开端,唤醒java开发者对fp in java的重新认识。
周六给javaparty讲了java中的函数编程(functional programming in java),但由于自己准备的不充分,讲的并不深入。估且再写点blog补充一下。当然,接下来的日子里,也打算挤点时间再深入钻研以下functor,感觉这个应用,将来会很广泛,即使java是一个oo语言,是面向状态的命令式编程(imperative programming)语言。
对于java语言来说,fp并不是其一个特长。但是functor却是一个很不错的新新亮点,虽然functor这个概念并不新,早在c++的stl就已经被提出来了:a functor is a function that can be manipulated as an object, or an object representing a single, generic function。―― 透过这个描述,我想我们可以较为这么说:functor=function object。所以,在oo语言中,纯粹的function是不存在的,在java语言中,function也是一个对象,这个对象就是functor。
但是,在java中,functor却因为java5对范型(generic)的支持,终于破土而出,成为一个新新亮点。而我也相信,这个亮点不会只是偶尔的闪烁,必将在未来的很多应用中,显示出璀璨的一面。
functor主要由三种类型:谓词(predicate),函数(function), 过程(procedure)。谓词的计算结果只返回布尔值;函数的计算计算返回一个对象;过程则只负责计算,没有返回结果
predicate
return a boolean value
function
return an object value
procedure
don't return anything
functor本身有一元/二元/三元???之分。当然,我对最为常见的就是一元(unarypredicate,unaryfunction,unaryprocedure)和二元(binnarypredicate,binnaryfunction,binnaryprocedure)。
上面都是一些很抽象的概念,那么一个functor到底什么样子呢?
首先让我们来看一个例子,通过这个例子来一步步明白functor的用处,明白什么是functor:
public static <t> list<t> select(collection<t> source, unarypredicate<t> selector) {
list<t> result = new arraylist<t>();
for(t item : source){
if( selector.test( item ) ){
result.add(item);
}
}
return result;
}
这个例子就是functor的典型应用,利用functor中的一元谓词,构造了一个select算法。
(未完,待明天继续) writed by 胡长城(银狐999)
闽公网安备 35060202000074号