枚举

在Scala中没有enum关键字。相反,Scala提供了一个Enumeration类,我们可以扩展这个类来创建枚举类型。

object demo10 {

  // 创建枚举类型
  object Stars extends Enumeration {
    type Stars = Value

    val 金星  = Value("金星是金色的")
    val 木星  = Value("木星是木头色的")
    val 火星  = Value("火星是火红颜色的")
    val 地球  = Value("地球是最美丽的蔚蓝色")
  }

  def main(args: Array[String]): Unit = {
    println("地球是什么颜色?")
    println(s"${Stars.地球.id},${Stars.地球}")

    // 打印枚举类型所有的值
    println(s"太阳系的卫星有 = ${Stars.values}")
    println(s"太阳系的卫星有 = ${Stars.maxId}")
  }
}

枚举类型的模式匹配

    // 枚举类型的模式匹配
    println("\n如何对枚举值进行模式匹配")
    Stars.values.foreach {
      case d if d == Stars.地球 || d == Stars.火星 => println(s"适合人类居住的星球 = $d")
      case _ => None
    }

如何更改枚举值的默认顺序

假设想要更改枚举值的默认顺序。在声明枚举元素时,可以将索引作为参数传递给Value类型。

  object Stars extends Enumeration {
    type Stars = Value

    val 金星      = Value(0, "金星是金色的")
    val 木星      = Value(2, "木星是木头色的")
    val 火星      = Value(4, "火星是火红颜色的")
    val 地球      = Value(-1, "地球是最美丽的蔚蓝色")
  }

《Spark原理深入与编程实战》