百度360必应搜狗淘宝本站头条
当前位置:网站首页 > IT技术 > 正文

函数式编程入门

wptr33 2025-02-08 13:05 25 浏览

1. 概述

1.1 函数式编程简介

Java作为面向对象的编程语言,如果按照编程种类划分属于命令式编程(Imperative Programming)。常见的编程范式还有逻辑式编程(Logic Programming),函数式编程(Functional Programming)。

函数式编程作为一种编程范式,在科学领域,是一种编写计算机程序数据结构和元素的 方式,它把计算过程当做是数学函数的求值,而避免更改状态和可变数据。

什么是函数式编程?简单的回答:一切都是数学函数。函数式编程语言里也可以有对

象,但通常这些对象都是恒定不变的 —— 要么是函数参数,要什么是函数返回值。函数式编程语言里没有 for/next 循环,因为这些逻辑意味着有状态的改变。相替代的是,这种循环逻辑在函数式编程语言里是通过递归、把函数当成参数传递的方式实现的。

2. Lambda 表达式

Java 8的最大变化是引入了Lambda(Lambda 是希腊字母 λ 的英文名称)表达式——一种紧凑的、传递行为的方式。

2.1 Lambda 表达式的形式

lambda表达式的语法由参数列表、箭头符号->和函数体组成。函数体既可以是一个表达 式,也可以是一个语句块。

表达式:表达式会被执行然后返回执行结果。

语句块:语句块中的语句会被依次执行,就像方法中的语句一样。

return语句会把控制权交给匿名方法的调用者。

break和continue只能在循环中使用。

如果函数体有返回值,那么函数体内部的每一条路径都必须返回值。

表达式函数体适合小型lambda表达式,它消除了return关键字,使得语法更加简洁。下面是一些lambda表达式:

(int x, int y) ‐> x + y 
( ) ‐> 42
(String s) ‐> { System.out.println(s); }

第一个lambda表达式接收 和 这两个整形参数并返回它们的和;第二个lambda表达

式不接收参数,返回整数'42';第三个lambda表达式接收一个字符串并把它打印到控制 台,不返回值。

2.2 常见应用

2.2.1 替代匿名内部类

毫无疑问,lambda表达式用得最多的场合就是替代匿名内部类,而实现Runnable接口 是匿名内部类的经典例子。lambda表达式的功能相当强大,用()->就可以代替整个匿名 内部类!请看代码:

如果使用匿名内部类:

@Test
public void oldRunable() {
new Thread(new Runnable() { @Override
public void run() {
System.out.println("The old runable now is using!");
}
}).start();
}

而如果使用lambda表达式:

@Test
public void runable() {
new Thread(() ‐> System.out.println("It's a lambda function!")).start();
}

最后的输出:

The old runable now is using!
  It's a lambda function!

是不是强大到可怕?是不是简单到可怕?是不是清晰明了重点突出到可怕?这就是

lambda表达式的可怕之处,用极少的代码完成了之前一个类做的事情!

2.2.2 使用lambda表达式对集合进行迭代

Java的集合类是日常开发中经常用到的,甚至说没有哪个java代码中没有使用到集合类。。。而对集合类最常见的操作就是进行迭代遍历了。请看对比:

@Test
public void iterTest() {
List languages = Arrays.asList("java","scala","python");
//before java8
for(String each:languages) { System.out.println(each);
}
//after java8
languages.forEach(x ‐> System.out.println(x));
  languages.forEach(System.out::println);
}

如果熟悉scala的同学,肯定对forEach不陌生。它可以迭代集合中所有的对象,并且将

lambda表达式带入其中。

languages.forEach(System.out::println);

这一行看起来有点像c++里面作用域解析的写法,在这里也是可以的。

2.2.3 用lambda表达式实现map

一提到函数式编程,一提到lambda表达式,怎么能不提map。没错,java8肯定也是支 持的。请看示例代码:

@Test
public void mapTest() {
List cost = Arrays.asList(10.0, 20.0,30.0); cost.stream().map(x ‐> x + x*0.05).forEach(x ‐>
System.out.println(x));
}

最后的输出结果:

10.5
21.0
31.5

map函数可以说是函数式编程里最重要的一个方法了。map的作用是将一个对象变换为 另外一个。在我们的例子中,就是通过map方法将cost增加了0.05倍的大小然后输出。

2.2.4 用lambda表达式实现mapreduce

既然提到了map,又怎能不提到reduce。reduce与map一样,也是函数式编程里最重要 的几个方法之一。map的作用是将一个对象变为另外一个,而reduce实现的则是将所有 值合并为一个,请看:

@Test
public void mapReduceTest() {
List cost = Arrays.asList(10.0, 20.0,30.0);
double allCost = cost.stream().map(x ‐> x+x*0.05).reduce((sum,x)
‐> sum + x).get();
System.out.println(allCost);
}

最终的结果为:

63.0

如果我们用for循环来做这件事情:

@Test
public void sumTest() {
List cost = Arrays.asList(10.0, 20.0,30.0); double sum = 0;
for(double each:cost) { each += each * 0.05; sum += each;
}
System.out.println(sum);
}

相信用map+reduce+lambda表达式的写法高出不止一个level。

2.2.5 filter操作

filter也是我们经常使用的一个操作。在操作集合的时候,经常需要从原始的集合中过滤 掉一部分元素。

@Test
public void filterTest() 
List cost = Arrays.as
List(10.0, 20.0,30.0,40.0); List filteredCost = cost.stream().filter(x ‐> x >25.0).collect(Collectors.toList());
filteredCost.forEach(x ‐> System.out.println(x));
}

最后的结果:

30.0
40.0

相关推荐

MySQL进阶五之自动读写分离mysql-proxy

自动读写分离目前,大量现网用户的业务场景中存在读多写少、业务负载无法预测等情况,在有大量读请求的应用场景下,单个实例可能无法承受读取压力,甚至会对业务产生影响。为了实现读取能力的弹性扩展,分担数据库压...

Postgres vs MySQL_vs2022连接mysql数据库

...

3分钟短文 | Laravel SQL筛选两个日期之间的记录,怎么写?

引言今天说一个细分的需求,在模型中,或者使用laravel提供的EloquentORM功能,构造查询语句时,返回位于两个指定的日期之间的条目。应该怎么写?本文通过几个例子,为大家梳理一下。学习时...

一文由浅入深带你完全掌握MySQL的锁机制原理与应用

本文将跟大家聊聊InnoDB的锁。本文比较长,包括一条SQL是如何加锁的,一些加锁规则、如何分析和解决死锁问题等内容,建议耐心读完,肯定对大家有帮助的。为什么需要加锁呢?...

验证Mysql中联合索引的最左匹配原则

后端面试中一定是必问mysql的,在以往的面试中好几个面试官都反馈我Mysql基础不行,今天来着重复习一下自己的弱点知识。在Mysql调优中索引优化又是非常重要的方法,不管公司的大小只要后端项目中用到...

MySQL索引解析(联合索引/最左前缀/覆盖索引/索引下推)

目录1.索引基础...

你会看 MySQL 的执行计划(EXPLAIN)吗?

SQL执行太慢怎么办?我们通常会使用EXPLAIN命令来查看SQL的执行计划,然后根据执行计划找出问题所在并进行优化。用法简介...

MySQL 从入门到精通(四)之索引结构

索引概述索引(index),是帮助MySQL高效获取数据的数据结构(有序),在数据之外,数据库系统还维护者满足特定查询算法的数据结构,这些数据结构以某种方式引用(指向)数据,这样就可以在这些数据结构...

mysql总结——面试中最常问到的知识点

mysql作为开源数据库中的榜一大哥,一直是面试官们考察的重中之重。今天,我们来总结一下mysql的知识点,供大家复习参照,看完这些知识点,再加上一些边角细节,基本上能够应付大多mysql相关面试了(...

mysql总结——面试中最常问到的知识点(2)

首先我们回顾一下上篇内容,主要复习了索引,事务,锁,以及SQL优化的工具。本篇文章接着写后面的内容。性能优化索引优化,SQL中索引的相关优化主要有以下几个方面:最好是全匹配。如果是联合索引的话,遵循最...

MySQL基础全知全解!超详细无废话!轻松上手~

本期内容提醒:全篇2300+字,篇幅较长,可搭配饭菜一同“食”用,全篇无废话(除了这句),干货满满,可收藏供后期反复观看。注:MySQL中语法不区分大小写,本篇中...

深入剖析 MySQL 中的锁机制原理_mysql 锁详解

在互联网软件开发领域,MySQL作为一款广泛应用的关系型数据库管理系统,其锁机制在保障数据一致性和实现并发控制方面扮演着举足轻重的角色。对于互联网软件开发人员而言,深入理解MySQL的锁机制原理...

Java 与 MySQL 性能优化:MySQL分区表设计与性能优化全解析

引言在数据库管理领域,随着数据量的不断增长,如何高效地管理和操作数据成为了一个关键问题。MySQL分区表作为一种有效的数据管理技术,能够将大型表划分为多个更小、更易管理的分区,从而提升数据库的性能和可...

MySQL基础篇:DQL数据查询操作_mysql 查

一、基础查询DQL基础查询语法SELECT字段列表FROM表名列表WHERE条件列表GROUPBY分组字段列表HAVING分组后条件列表ORDERBY排序字段列表LIMIT...

MySql:索引的基本使用_mysql索引的使用和原理

一、索引基础概念1.什么是索引?索引是数据库表的特殊数据结构(通常是B+树),用于...