lambda表达式和stream流

Lambda表达式是Python中的一种匿名函数,其结构简单,使用方便,可用于函数式编程,常见于函数式编程库或其他函数式编程语言中。

Lambda表达式的语法形式为:lambda arguments: expression

其中,arguments表示该函数接受的参数,可以是一个或多个。多个参数使用逗号分隔。expression表示该函数的返回值。

Lambda表达式的特点:

  1. 简洁:Lambda表达式可以用很少的代码来实现简单的函数功能。

  2. 速度快:Lambda表达式通常比普通函数执行更快。

  3. 可以作为参数传递:Lambda表达式可以作为参数传递给其他函数。

  4. 内置函数:Python中许多内置函数都支持Lambda表达式作为参数。

  5. 匿名函数:Lambda表达式是一种匿名函数,不需要定义函数名。

  6. 函数式编程:Lambda表达式适用于函数式编程的场景。

Lambda表达式使用示例:

  1. 使用Lambda表达式计算两个数的和:

sum = lambda x, y: x + y

print(sum(2, 3)) # 5

  1. 使用Lambda表达式将列表中的元素进行平方:

lst = [1, 2, 3, 4, 5]

result = list(map(lambda x: x**2, lst))

print(result) # [1, 4, 9, 16, 25]

  1. 使用Lambda表达式过滤出列表中的偶数元素:

lst = [1, 2, 3, 4, 5]

result = list(filter(lambda x: x % 2 == 0, lst))

print(result) # [2, 4]

Stream流是Java 8中新引入的一个API,用来对集合进行函数式操作和流水线操作,其本质是一组函数式接口的集合。

Stream流的特点:

  1. 不存储数据:Stream流不是数据结构,而是一种计算过程,不会改变原集合中的元素。

  2. 惰性求值:Stream流的操作不会立即执行,只有当遇到终止操作时才会执行。

  3. 支持并行处理:Stream流可以分成多个部分进行并行操作,提高了处理效率。

Stream的操作分为两类:中间操作和终止操作。

中间操作:

中间操作是对源数据集合的数据进行处理,并返回一个新的Stream流,其中包括过滤数据、映射数据、去重、排序等操作。

常见的中间操作:

  1. filter:过滤符合条件的元素。

  2. map:将一个元素映射为另一个元素。

  3. flatMap:将一个元素映射为多个元素。

  4. distinct:去重。

  5. sorted:排序。

  6. limit:截取前n个元素。

  7. skip:跳过前n个元素。

终止操作:

终止操作是对Stream流中的数据进行处理,返回一个结果或一个副作用,其中包括计数、最大值、最小值、求和、平均值、分组、汇聚等操作。

常见的终止操作:

  1. forEach:对每个元素进行操作。

  2. count:统计元素个数。

  3. max/min:求最大值/最小值。

  4. reduce:对元素进行汇聚。

  5. collect:将Stream流转化为其他数据结构。

Stream流使用示例:

  1. 对一个集合进行筛选:

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);

Stream<Integer> stream = list.stream(); // 将集合转化成Stream流

stream.filter(n -> n % 2 == 0) // 过滤偶数

.forEach(System.out::println); // 输出2, 4

  1. 统计一个集合中的元素个数:

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);

Stream<Integer> stream = list.stream(); // 将集合转化成Stream流

long count = stream.count(); // 统计元素个数

System.out.println(count); // 输出5

  1. 求一个集合的平均值:

List<Integer> list = Arrays.asList(1, 2, 3, 4, 5);

Stream<Integer> stream = list.stream(); // 将集合转化成Stream流

OptionalDouble average = stream.mapToInt(Integer::intValue) // 转化成IntStream

.average(); // 求平均值

System.out.println(average.getAsDouble()); // 输出3.0

相关推荐
zone773921 小时前
001:简单 RAG 入门
后端·python·面试
F_Quant21 小时前
🚀 Python打包踩坑指南:彻底解决 Nuitka --onefile 配置文件丢失与重启报错问题
python·操作系统
允许部分打工人先富起来1 天前
在node项目中执行python脚本
前端·python·node.js
IVEN_1 天前
Python OpenCV: RGB三色识别的最佳工程实践
python·opencv
haosend1 天前
AI时代,传统网络运维人员的转型指南
python·数据网络·网络自动化
曲幽1 天前
不止于JWT:用FastAPI的Depends实现细粒度权限控制
python·fastapi·web·jwt·rbac·permission·depends·abac
IVEN_2 天前
只会Python皮毛?深入理解这几点,轻松进阶全栈开发
python·全栈
Ray Liang2 天前
用六边形架构与整洁架构对比是伪命题?
java·python·c#·架构设计
AI攻城狮2 天前
如何给 AI Agent 做"断舍离":OpenClaw Session 自动清理实践
python
千寻girling2 天前
一份不可多得的 《 Python 》语言教程
人工智能·后端·python