Java学习笔记首页投稿(暂停使用,暂停投稿)

java8入门必备——函数式编程思维——过滤函数的同义异名问题

2017-09-30  本文已影响51人  每天学点编程

请关注我的微信公众号


个人微信公众号

技术交流群 (仅作技术交流):642646237
请关注我的头条号:


函数的同义异名问题——演示各类函数式语言中的用法

作为函数式编程语言的共同特征,在每一种语言里都可以找到同样的几大类基本函数。

不过继承函数式传统的语言喜欢按照范式术语来命名基本函数,而出自脚本语言背景的则更喜欢使用描述性的名字(有时候还会起多个名字,实质是指向相同函数的别名)。

函数的同义异名问题——演示各类函数式语言中的用法——筛选

筛选函数将用户(以高阶函数的形式)给定的布尔逻辑作用于集合,返回由原集合中符合条件的元素组成的一个子集。筛选操作与查找(find)函数的关系很密切,查找函数返回的是集合中第一个符合条件的元素。

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Scala——filter

利用Scala的隐式参数(implicit parrameter)特性可以让例子变得更简短:

filter()可以用于任意的集合。

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Scala——partition

返回结果是由原集合的内容划分而成的两个集合,原集合本身保持不变。划分的依据是用户传进来作为筛选条件的高阶函数。


函数的同义异名问题——演示各类函数式语言中的用法——筛选——Scala——find

filter()函数返回所有匹配元素的集合,而find()只返回第一个匹配项:

find()并不直接把匹配项作为返回值,而是用Option类作了一层包装。Option有两个可能的取值:Some或者None

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Scala——takeWhile()

根据一个传入的断言来决定元素去留的。
takeWhile()函数从集合头部开始,一直取到第一个不满足断言的元素:

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Scala——dropWhile()函数

从集合头部开始,一直丢弃满足断言的元素,直到遇到第一个非匹配项:

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Groovy——findAll()函数

Groovy一般不被看作一种函数式语言,但它具备很多函数式的范式,只是命名上往往带有脚本语言的色彩。
按照函数式语言的传统一般叫作filter()的函数,对应的是Groovy的findAll()方法:

这个方法也像Scala的筛选函数一样,适用于所有的类型,包括字符串:

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Groovy——split()函数

Groovy也有跟partition()对应的函数,叫作split()

split()方法的返回值是一个嵌套的数组,类似于Scala的partition()函数返回的嵌套列表。

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Groovy——find()函数

Groovy的find()方法返回集合中的第一个匹配项:

find()找不到匹配项的时候,Groovy没有采用Scala防范空值的做法,而是按照Java的习惯直接返回null

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Groovy——takeWhile()函数

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Groovy——dropWhile()函数

和Scala的例子一样,Groovy的dropWhile()也是作为一种特殊的筛选来使用的。它丢弃满足断言的最长前缀,换言之,被筛选到的只是列表开头的一部分:

函数的同义异名问题——演示各类函数式语言中的用法——筛选——Clojure——(filter )函数

Clojure用于操纵集合的招式数量多得惊人,而且Clojure语言的动态类型特征,这些函数一般还都是泛型的函数。
Clojure在命名上沿袭函数式编程的传统。

Clojure和另外两种语言一样,提供了针对简单匿名函数的简写语法:

Clojure的函数也像另外两种语言一样,适用于各种类型,包括字符串:

Clojure给(filter )设定的返回值类型是SeqSeq接口是Clojure用于表示序列型集合的核心抽象,用一对圆括号括起来的就是一个Seq

上一篇下一篇

猜你喜欢

热点阅读