你可以做到這一點很好地使用半羣與scalaz或貓附加:
import scalaz._, Scalaz._ // for cats use `import cats._, implicits._`
val opt1 = Option(List("Sal", "Salil"))
val opt2 = Option(List("Sal2", "Salil2"))
scala> opt1 |+| opt2
res0: Option[List[String]] = Some(List(Sal, Salil, Sal2, Salil2))
scala> opt1 |+| None
res1: Option[List[String]] = Some(List(Sal, Salil))
scala> Option.empty[List[String]] |+| None
res2: Option[List[String]] = None
否則,標準庫,你可能需要處理其案件逐案:
(opt1, opt2) match {
case (Some(a), Some(b)) => Option(a ++ b)
case (Some(a), None) => Option(a)
case (None, Some(b)) => Option(b)
case _ => None
}
或使用收集方法將它們弄平:
scala> List(opt1, opt2).flatten.flatten
res5: List[String] = List(Sal, Salil, Sal2, Salil2)
scala> List(opt1, None).flatten.flatten
res6: List[String] = List(Sal, Salil)
這不會返回正確的值,如果兩個輸入都爲'一些(名單())'。這應該返回'Some(List())',但是你的解決方案返回'None'。 –