文档章节

第十章 Scala 容器基础(十六):flatMap一个把flatten和map结合起来的方法

阿拉德大陆的魔法师
 阿拉德大陆的魔法师
发布于 2016/04/13 11:56
字数 733
阅读 2538
收藏 0

Problem

    当你第一次来到Scala世界的时候,flatMap放方法看起来是很特别的,所以你需要理解他是如何工作的,还有它是应用在什么地方的。

Solution

    在你调用map方法后紧接着调用flatten方法的情况下,你就可以尝试调用flatMap来解决这个问题了。满足如下情况:

  • 使用map方法来从原集合基础上创建一个新的集合

  • map方法的返回结果是一个嵌套集合,或者元素为Some和None

  • 你在map方法后紧接着调用了flatten方法

    如果你的程序正好符合上面的情况,那么你就是可以使用flatMap来代替collection.map.flatten了

    下面这个例子中,你会看到如何使用flatMap来处理一个Option。在这个例子中,我们要计算集合中数字类型元素的和。又一个问题:数字都是字符串类型的,并且好多元素并不是数字,也不能转换为Int型。先来看下这个集合:

scala> val bag = List("1", "2", "three", "4", "one hundred seventy five")
bag: List[String] = List(1, 2, three, 4, one hundred seventy five)

    为了解决这个问题,你开始创建一个字符串到整形的转换函数来返回Some[Int]或者None:

scala> def toInt(in: String): Option[Int] = {
     |   try {
     |     Some(Integer.parseInt(in.trim))
     |   } catch {
     |     case e: Exception => None
     |   }
     | }
toInt: (in: String)Option[Int]

    下面我们来看看使用flatMap的效果:

scala> bag.flatMap(toInt).sum
res23: Int = 7

scala> bag.flatMap(toInt)
res24: List[Int] = List(1, 2, 4)

Discussion

    为了看清楚flatMap是如何工作的,我们吧这个问题拆分成几小步。首先,你要知道当你调用map方法会发生什么:

scala> bag.map(toInt)
res26: List[Option[Int]] = List(Some(1), Some(2), None, Some(4), None)

    map方法使toInt函数作用在了集合的每个元素上,并且返回了一组Some[Int]和None的集合。但是sum方法要作用在List[Int]上,怎么办?上节踢桃flatten方法可以把集合中Some里的数据展开,然后抛弃None。

scala> bag.map(toInt).flatten
res27: List[Int] = List(1, 2, 4)

    这次我们就能够调用sum方法了:

scala> bag.map(toInt).flatten.sum
res28: Int = 7

    哇,我看到了map.flatten的结构,我想到了“flat map”,所以我就可以使用flatMap方法了:

scala> bag.flatMap(toInt).sum
res23: Int = 7

    一旦你得道了一个原始集合,并且想把它转换为List[Int]。你可以调用丰富的集合方法来获取你想要的结果:

scala> bag.flatMap(toInt).filter(_ > 1)
res29: List[Int] = List(2, 4)

scala> bag.flatMap(toInt).takeWhile(_ < 4)
res30: List[Int] = List(1, 2)

scala> bag.flatMap(toInt).partition(_ > 3)
res31: (List[Int], List[Int]) = (List(4),List(1, 2))

  

© 著作权归作者所有

阿拉德大陆的魔法师
粉丝 27
博文 91
码字总数 83019
作品 0
西城
程序员
私信 提问
scala-常用函数介绍

欢迎大家关注: scala工具库 ,里面包含各种库的测试用例和使用说明文档 模式匹配 使用用模式匹配实现斐波那契 元组tuple 元组可以保存不同类型的值,不能通过名称获取字段,而是使用位置下标...

jacksu
2015/11/25
140
0
Traversing Mapping Filtering Folding Reducing

Traversing Mapping Filtering Folding Reducing Traversal 使用 foreach 遍历集合。foreach 是从特质 Iterable 混入而来的。 The signature of foreach is the following: trait Iterabl......

秋风醉了
2015/04/29
42
0
第十章 Scala 容器(三):使用容器通用方法解决问题

综述 Scala的容器类主要提供了下面这些方法来使用它它们:1. 过滤;2. 遍历;3. 分区; 4. 数学统计;5. 其他。我们来详细看看这些方法 2. 容器通用方法(Common methods on Traversable col...

阿拉德大陆的魔法师
2016/04/03
475
0
第十章 Scala 容器基础(十二):使用Iterators

Problem 你需要在你的应用中使用iterator。 Solution 尽管使用带有hasNext()和next()方法的iterator是非常通用的遍历Java集合的方法。但是它们在Scala集合中并不经常被使用。因为Java集合有许...

阿拉德大陆的魔法师
2016/04/12
342
0
【Spark亚太研究院系列丛书】Spark实战高手之路-第2章动手实战Scala第3小节(1)

函数式编程的核心特色之一是把函数作为参数传递给函数、在函数内部可以定义函数等。 1,动手实战Scala高阶函数 声明一个List集合实例: List集合所在的包已经被预定义自动导入,所以此处不需...

Spark亚太研究院
2014/12/01
138
0

没有更多内容

加载失败,请刷新页面

加载更多

只需一步,在Spring Boot中统一Restful API返回值格式与统一处理异常

统一返回值 在前后端分离大行其道的今天,有一个统一的返回值格式不仅能使我们的接口看起来更漂亮,而且还可以使前端可以统一处理很多东西,避免很多问题的产生。 比较通用的返回值格式如下:...

晓月寒丶
昨天
59
0
区块链应用到供应链上的好处和实际案例

区块链可以解决供应链中的很多问题,例如记录以及追踪产品。那么使用区块链应用到各产品供应链上到底有什么好处?猎头悬赏平台解优人才网小编给大家做个简单的分享: 使用区块链的最突出的优...

猎头悬赏平台
昨天
28
0
全世界到底有多少软件开发人员?

埃文斯数据公司(Evans Data Corporation) 2019 最新的统计数据(原文)显示,2018 年全球共有 2300 万软件开发人员,预计到 2019 年底这个数字将达到 2640万,到 2023 年达到 2770万。 而来自...

红薯
昨天
65
0
Go 语言基础—— 通道(channel)

通过通信来共享内存(Java是通过共享内存来通信的) 定义 func service() string {time.Sleep(time.Millisecond * 50)return "Done"}func AsyncService() chan string {retCh := mak......

刘一草
昨天
58
0
Apache Flink 零基础入门(一):基础概念解析

Apache Flink 的定义、架构及原理 Apache Flink 是一个分布式大数据处理引擎,可对有限数据流和无限数据流进行有状态或无状态的计算,能够部署在各种集群环境,对各种规模大小的数据进行快速...

Vincent-Duan
昨天
60
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部