今天特意学习一下Option类型
一般来说,对于每种语言都会有一个关键字来表示一个对象引用的“无”。比如在Java中使用的是null。
在Scala中是融合了函数式编程的风格,当预计到变量或者函数返回值可能不会引用任何值的时候,使用Option类型。
Option(选项)类型用来表示一个值。(有值或无值)。
Option[T] 是一个类型为 T 的一个可选值的容器。
Option类包含一个子类Some,当存在可以被引用的值的时候,也就是有值,就可以使用Some来包含这个值。比如Option(“CSDN”)
Option类还包含了一个子类None,没有值。Some和None都是它的子类,他们都是final类,所以不能再有派生子类了。
Option实例就是Some或者None对象实例。
可以通过代码来学习一下:
scala> val book = Map("hadoop" -> 10,"spark" -> 100,"hbase" -> 1000);//我们在scala shell中定义了一个Map
book: scala.collection.immutable.Map[String,Int] = Map(hadoop -> 10, spark -> 100, hbase -> 1000)
scala> book.get("hadoop")//然后我们从Map中获取键为hadoop的映射
res0: Option[Int] = Some(10) //我们取到的值的类型为Option[Int],值被包含在Some中返回,读取实际是对Some进行的操作<br>
scala> book.get("hive")//我们再从Map中获取键为hive的映射
res1: Option[Int] = None//这个值是不存在的,所以返回的值是None对象<br>
Option实际上是一个容器
我们可以把它看做成一个集合,这不过这个集合要么只包含一个包含在Some中的元素,要么不存在元素显示None
其实它并不是一个真正的集合类,因为它并没有有继承Traversable或Iterable。
但是它确实具有Iterable的所有操作,这意味着你完全可以把Option当成一个集合去使用。
Option类可以使用大部分的集合操作。例如 map、foreach、filter等