在Scala中使用“ for”和“ match”进行选项处理之间的区别

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)

Tim*_*Tim 6

最干净的版本可能是这样的:

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呼叫。