文档章节

函数式编程介绍

Crazy_Coder
 Crazy_Coder
发布于 2017/05/23 16:14
字数 684
阅读 26
收藏 1

##什么是函数式编程 函数式编程是种编程典范,它将电脑运算视为函数的计算。函数编程语言最重要的基础是 λ 演算(lambda calculus)。而且λ演算的函数可以接受函数当作输入(参数)和输出(返回值)。和指令式编程相比,函数式编程强调函数的计算比指令的执行重要。和过程化编程相比,函数式编程里,函数的计算可随时调用。

##Guava中的函数式编程 为了支持函数式编程,Guava提供了下面这两个接口:

public interface Function<F, T> {
    @Nullable T apply(@Nullable F input);
}
public interface Predicate<T> {
    boolean apply(@Nullable T input);
}

举个例子:在一群People对象中,找到年龄大于20的People

  • 通常做法:
List<Person> oldPeople = new ArrayList<Person>(); 
for (Person person : people) { 
    if (person.getAge() >= 20) { 
        oldPeople.add(person); 
    }
}
  • 在Guava中提供了filter模式,filter即从一个集合中根据一个条件筛选元素。
    • 找出age大于20的
    List<Person> oldPeople = Lists.newArrayList(Collections2.filter(people, new Predicate<Person>() { 
        public boolean apply(Person person) { 
            return person.getAge() >= 20; 
        } 
    }));
    
    • 找出name中含有字符w的
    List<Person> oldPeople = Lists.newArrayList(Collections2.filter(people, new Predicate<Person>() { 
        public boolean apply(Person person) { 
            return person.getName().contains("w");
        } 
    }));
    
    • 找出age>20并且name中含有字符w的人
    // 一般大家都会这么写,当然这种写法是可以的
    List<Person> oldPersons = Lists.newArrayList(Collections2.filter(persons, new Predicate<Person>() {
        public boolean apply(Person person) {
            return person.getAge() >= 20 && person.getName().contains("w");
        }
    }));
    

这样写的话就有一定的代码重复,因为之前我们已经写了两个Predicate来分别实现这两个条件判断,能不能重用之前的Predicate那?答案是能。 我们首先将之前生成年龄判断和名称判断的两个Predicate抽成方法。 java private Predicate<Person> ageBiggerThan(final int age) { return new Predicate<Person>() { public boolean apply(Person person) { return person.getAge() >= age; } }; } private Predicate<Person> nameContains(final String str) { return new Predicate<Person>() { public boolean apply(Person person) { return person.getName().contains(str); } }; } //而我们的结果其实就是这两个Predicate相与。Guava给我们提供了and方法,用于对一组Predicate求与。 List<Person> filteredPeople = Lists.newArrayList(Collections2.filter(people, Predicates.and(ageBiggerThan(20), nameContains("w"))));

##JDK8中的函数式编程 在上面的例子中:

  • 在一群People对象中,找到年龄大于20的People
List<Person> filteredPeople = persons.stream().filter(p -> p.getAge() >= 20).collect(Collectors.toList());  
  • 找出name中含有字符w的
List<Person> filteredPeople = persons.stream().filter(p -> p.getName().contains("w")).collect(Collectors.toList());  

##总结

  1. 无法升级jdk版本的项目,推荐使用guava

    guava作为jdk8最好的替代品,是值得使用的

  2. 可以平稳升级jdk的项目,推荐使用jdk8

    jdk8天生的优势,注定它优于guava,再加上后来引入的lambda表达式,使jdk8的语法更加优美

  3. jdk8出生于guava之后,所以说,jdk8很多地方都是借鉴于guava

© 著作权归作者所有

共有 人打赏支持
上一篇: guava vs jdk8
下一篇: Dockerfile说明
Crazy_Coder

Crazy_Coder

粉丝 143
博文 24
码字总数 23648
作品 5
南京
程序员
私信 提问
《RxJava 2.x 实战》

我最近写了一本书《RxJava 2.x 实战》。 该书由电子工业出版社出版,目前已经在淘宝、京东、当当、亚马逊等各大电商平台上进行销售或预售。 天猫电子工业出版社旗舰店 https://detail.tmall...

fengzhizi715
2018/04/28
0
0
Cats(一):从函数式编程思维谈起

本文由 Yison 发表在 ScalaCool 团队博客。 Cats logo 如果你看到一个开源类库,logo 是四只猫 + 五个箭头,可能会略感不适 — 这是工程代码里可以使用的玩意儿吗? 没错,这是 TypeLevel 设...

ScalaCool
2017/11/30
0
0
函数式编程基础思想

说明 网上有很多深入语言层次讲解函数式编程的应用,很多人无法理解,能用但是一头雾水,死记硬背,原因究其是核心思想不清楚。 我说的语言层次上的,例如 Spark MapReduce lambda Groovy Rx...

热血沸腾
2017/12/20
0
0
[Swift]以函数式编程的方式使用字符串中的Ranges

原文:Swift: Using String Ranges The Functional Way 几周之前,我介绍了『Swift中如何使用Range截取字符串』。那时,Swift中使用Range为什么如此艰难让人疑惑不解,但是至少我们找到一种可...

Redding
2014/12/18
0
0
iOS 中的链式编程、函数式编程入门

对一个程序猿来说,从一开始接触编程后会逐渐经历好几个不同的编程思想。包括过程式编程、面向对象编程、响应式编程、函数式编程、链式编程等等。 的特点是随着程序的编写逐步进行,写到哪儿...

BennyLoo
2017/11/08
0
0

没有更多内容

加载失败,请刷新页面

加载更多

OSChina 周一乱弹 —— 白掌柜说了卖货不卖身

Osc乱弹歌单(2019)请戳(这里) 【今日歌曲】 @爱漫爱 :这是一场修行分享羽肿的单曲《Moony》 手机党少年们想听歌,请使劲儿戳(这里) @clouddyy :开不开心? 开心呀, 我又不爱睡懒觉…...

小小编辑
今天
7
0
大数据教程(11.7)hadoop2.9.1平台上仓库工具hive1.2.2搭建

上一篇文章介绍了hive2.3.4的搭建,然而这个版本已经不能稳定的支持mapreduce程序。本篇博主将分享hive1.2.2工具搭建全过程。先说明:本节就直接在上一节的hadoop环境中搭建了! 一、下载apa...

em_aaron
今天
2
0
开始看《JSP&Servlet学习笔记》

1:WEB应用简介。其中1.2.1对Web容器的工作流程写得不错 2:编写Servlet。搞清楚了Java的Web目录结构,以及Web.xml的一些配置作用。特别是讲了@WebServlet标签 3:请求与响应。更细致的讲了从...

max佩恩
今天
4
0
mysql分区功能详细介绍,以及实例

一,什么是数据库分区 前段时间写过一篇关于mysql分表的的文章,下面来说一下什么是数据库分区,以mysql为例。mysql数据库中的数据是以文件的形势存在磁盘上的,默认放在/mysql/data下面(可...

吴伟祥
今天
3
0
SQL语句查询

1.1 排序 通过order by语句,可以将查询出的结果进行排序。放置在select语句的最后。 格式: SELECT * FROM 表名 ORDER BY 排序字段ASC|DESC; ASC 升序 (默认) DESC 降序 1.查询所有商品信息,...

stars永恒
今天
4
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部