hex*_*nov 1 monads functional-programming scala pattern-matching optional
我目前正在学习Scala,遇到了两种处理选项的方法。结果是相同的,但我想知道使用一个相对于另一个是否有优势(或者是否有更好的选择)。
如果输入也可以除以4,则divByTwo1和divByTwo2函数将返回输入除以2,否则将返回None。
def divByFour(i: Int): Option[Int] = {
if (i % 4 == 0) {
Some(i / 4)
} else {
None
}
}
def divByTwo1(i: Int): Option[Int] = {
for {
fourth <- divByFour(i)
} yield fourth * 2
}
def divByTwo2(i: Int): Option[Int] = {
divByFour(i) match {
case Some(fourth) => Some(fourth * 2)
case None => None
}
}
Run Code Online (Sandbox Code Playgroud)
最干净的版本可能是这样的:
def divByTwo(i: Int): Option[Int] = divByFour(i).map(_ * 2)
Run Code Online (Sandbox Code Playgroud)
作为一般规则,我会用map/ flatMap/ filter时的结果是Option,因为它使内部的计算Option容器。使用match/ fold/ getOrElse当你从提取数据Option的容器,其结果是一些其他类型。
使用for作为处理多一个便捷的方式map/ flatMap/ filter电话,但我个人避免单个map呼叫。