提取器是从表达式中获取值

第27讲中的match代码也是一种提取器

    def match_array(arr : Any) = arr match {
      case Array(x) => println("Array(1):",x) // 长度为1的数组,x代表数组中的值
      case Array(x,y) =>  println("Array(2):",x,y) // 长度为2的数组,x代表数组中的第一个值
      case Array(x,_*) => println("任意一维数组:",x) //任意长度数组,取第一个值
      case Array(_*) => println("任意一维数组") //任意长度数组
     }
     
    match_array(Array(0))
    match_array(Array("spark"))
    match_array(Array("spark","scala"))
    match_array(Array("spark","scala",0,4))

将数组中的元素提取给case中定义的常量,例如x,y 


还有一个使用正则表达式提取数据的提取器

    val pattern = "([0-9]+) ([a-z]+)".r
    "2016 spark" match {
      case pattern(num,item) => println(num+" "+item)
    }