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

相关推荐
源图客2 小时前
【亚马逊 SP-API 实战】Java 批量创建变体 Listing(父商品 + 子变体 + 独立图片)完整教程(亲测可用)
java·大数据·python
Cinthia10032 小时前
学习深度学习过程中对线性代数的几何理解
python·线性代数·机器学习
Xpower 172 小时前
Codex 桌面端更新后 Chrome 插件和 Computer Use 不可用,怎么排查和修复
前端·人工智能·chrome·python·学习
不会C语言的男孩3 小时前
C++ Primer 第3章:字符串、向量和数组
开发语言·c++
兰令水3 小时前
leecodecode【反前后指针】【2026.5.31打卡-java版本】
java·开发语言
Dovis(誓平步青云)4 小时前
《QT学习第四篇:常见事件与UDP、TCP、文件系统、(锁、信号量、条件变量》
c语言·开发语言·汇编·qt
Wang ruoxi4 小时前
Pygame 小游戏——贪吃蛇
python·pygame
大数据魔法师9 小时前
Streamlit(二十三)- 教程(二)- 动态导航
python·web
心中有国也有家11 小时前
GE图引擎深度解析——CANN的计算图优化与执行引擎
人工智能·pytorch·python·学习·numpy
卷毛的技术笔记12 小时前
告别硬编码!Spring AI Alibaba 实现 AI Agent 智能工具调用(Tool Calling)
java·人工智能·后端·python·spring·ai编程