从Scala中的Option [..]获取java.io.Serializable

时间:2016-10-17 19:22:26

标签: scala null scala-option

(几周前刚开始使用Scala,所以请耐心等待)

在这里阅读/试用这篇小文章,遇到了一些惊喜

http://danielwestheide.com/blog/2012/12/19/the-neophytes-guide-to-scala-part-5-the-option-type.html

根据描述定义案例类User:

case class User(
  id: Int,
  firstName: String,
  lastName: String,
  age: Int,
  gender: Option[String])

object UserRepository {
  private val users = Map(1 -> User(1, "John", "Doe", 32, Some("male")),
                          2 -> User(2, "Johanna", "Doe", 30, None))
  def findById(id: Int): Option[User] = users.get(id)
  def findAll = users.values
}

,以下是我观察到的内容:

> scala> UserRepository.findById(1)
> res34: Option[User] = Some(User(1,John,Doe,32,Some(male)))
> 
> scala> UserRepository.findById(1).get
> res35: User = User(1,John,Doe,32,Some(male))
> 
> scala> UserRepository.findById(1).getOrElse("N/A")
> res36: java.io.Serializable = User(1,John,Doe,32,Some(male))
>
> scala> UserRepository.findById(3).getOrElse("N/A")
> res37: java.io.Serializable = N/A

前两个是我的预期,但后两个不是;现有和不存在用户的情况。为什么java.io.Serializable,突然之间?

1 个答案:

答案 0 :(得分:4)

要理解这一点,您必须了解getOrElse

是什么
final def getOrElse[B >: A](default: => B): B

getOrElseOption上定义。 Option可以是Some(value)None

getOrElsedefault

时,

option会返回none

val map = Map(1 -> 2)

map.get(1)返回option

scala> Some(1).getOrElse(2)
res3: Int = 1

scala> Some(1).getOrElse("Hello")
res4: Any = 1


scala> case class User(name: String)
defined class User

scala> (None: Option[User]).getOrElse("a")
res12: java.io.Serializable = a

scala> (None: Option[User]).getOrElse(1)
res7: Any = 1

即将到来

Some(a).getOrElse(b)

如果ab属于同一类型,则结果类型将为a类型或b类型

如果ab是同一类型的not,则结果类型将是最接近的常见超类型,在您的情况下为java.io.Serializable

请注意

1)最近的User公共超类型和String是Serializable

2)User和Int的最近公共超类型是任意