Erlang的list-at-a-time操作 与 Perl的函数型编程

2> Even = fun(X) -> ( X rem 2 ) =:= 0 end.
#Fun<erl_eval.6.80247286>

3> List = [1,2,3,4,5,6,7,8].
[1,8]

4> lists:map(Even,List).
[false,true,false,true]

5> lists:filter(Even,List).
[2,8]

像上面的map和filter这样在一个函数调用(Even)中处理整个列表的操作称为list-at-a-time操作。list-at-a-time操作让程序更简洁易懂。

这让我想到了Perl中的grep()和map()函数

C:/>perl
@numbers = (1 .. 8);
print grep { !($_ % 2) } @numbers;
^Z
2468

刚开始学习Erlang,结合Perl的一些经验,理解和使用起来更快一些。

(以下摘自http://www.ibm.com/developerworks/cn/linux/sdk/road/part4/

Perl 本质上是过程型语言,在 Perl 中,函数型编程只能是一种方法。实际解决方案一般都使用 map() 或 grep() 函数来模拟函数解决方案。函数型编程方法之所以有价值有三个原因。首先,FP 可以使程序员以全新的角度看待问题,并可能因此想出更好的解决方案。第二,没有 map() 和 grep() 的帮助,Schwartzian 和 Guttman-Rosler 变换以及很多其它 Perl 习惯用法都难以使用和理解。第三,Perl的函数调用消耗系统资源相当多,所以,不使用 map() 和 grep() 而实现某些算法会极大地降低算法性能

相关文章

1. 如何去重 #!/usr/bin/perl use strict; my %hash; while(...
最近写了一个perl脚本,实现的功能是将表格中其中两列的数据...
表的数据字典格式如下:如果手动写MySQL建表语句,确认麻烦,...
巡检类工作经常会出具日报,最近在原有日报的基础上又新增了...
在实际生产环境中,常常需要从后台日志中截取报文,报文的形...
最近写的一个perl程序,通过关键词匹配统计其出现的频率,让...