2021年大数据常用语言Scala(二十一):函数式编程 遍历 foreach

Posted Lansonli

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了2021年大数据常用语言Scala(二十一):函数式编程 遍历 foreach相关的知识,希望对你有一定的参考价值。

目录

遍历  foreach

使用类型推断简化函数定义

使用下划线来简化函数定义


遍历  foreach

之前,学习过了使用for表达式来遍历集合。我们接下来将学习scala的函数式编程,使用foreach方法来进行遍历、迭代。它可以让代码更加简洁。

用途:

foreach 会帮我们对集合中的每一个元素取出来进行处理, 处理的逻辑由我们自行定义

集合中的元素,都会传入给你提供的函数去计算

 

方法签名

foreach(f: (A) ⇒ Unit): Unit

f 表明一个函数, A表明传入的参数 =>表明函数返回值是Unit, foreach 整体返回值Unit

说明

foreach

API

说明

参数

f: (A) ⇒ Unit

接收一个函数对象<br />函数的输入参数为集合的元素,返回值为空

返回值

Unit

 

foreach执行过程

我们传入foreach的是一个函数, 那么怎么工作的呢?

foreach 帮我们把集合中的每一个元素取出来, 然后传给函数, 然函数进行操作

如下图

 

示例

有一个列表,包含以下元素1,2,3,4,请使用foreach方法遍历打印每个元素

 

参考代码

// 定义一个列表
scala> val a = List(1,2,3,4)
a: List[Int] = List(1, 2, 3, 4)

// 迭代打印
scala> a.foreach((x:Int)=>println(x))

 

使用类型推断简化函数定义

上述案例函数定义有点啰嗦,我们有更简洁的写法。因为使用foreach去迭代列表,而列表中的每个元素类型是确定的

  • scala可以自动来推断出来集合中每个元素参数的类型
  • 创建函数时,可以省略其参数列表的类型

 

示例

有一个列表,包含以下元素1,2,3,4,请使用foreach方法遍历打印每个元素

使用类型推断简化函数定义

 

参考代码

scala> val a = List(1,2,3,4)
a: List[Int] = List(1, 2, 3, 4)

// 省略参数类型
scala> a.foreach(x=>println(x))

 

使用下划线来简化函数定义

当函数参数,只在函数体中出现一次,而且函数体没有嵌套调用时,可以使用下划线来简化函数定义

我们来强调一下要求:

参数只在函数体(注意是函数体, 不包含参数定义那里)里出现一次

对这个参数没有复杂的调用, 如(if for 等循环 或迭代等嵌套, 或者在println语句中等(通俗来说就是被括号包起来了))

示例

有一个列表,包含以下元素1,2,3,4,请使用foreach方法遍历打印每个元素

使用下划线简化函数定义

 

参考代码

scala> val a = List(1,2,3,4)
a: List[Int] = List(1, 2, 3, 4)

a.foreach(println(_))

 

  • 如果方法参数是函数,如果出现了下划线,scala编译器会自动将代码封装到一个函数中
  • 参数列表也是由scala编译器自动处理

https://www.baeldung.com/scala/underscore

以上是关于2021年大数据常用语言Scala(二十一):函数式编程 遍历 foreach的主要内容,如果未能解决你的问题,请参考以下文章

2021年大数据常用语言Scala(二十):函数式编程 介绍

2021年大数据常用语言Scala(二十七):函数式编程 聚合操作

2021年大数据常用语言Scala(二十四):函数式编程 过滤  filter

2021年大数据常用语言Scala(二十六):函数式编程 分组 groupBy

2021年大数据常用语言Scala(二十二):函数式编程 映射 map

2021年大数据常用语言Scala(二十三):函数式编程 扁平化映射 flatMap