所谓提取器,就是从表达式获取具体值。
其作用,可以根据某一规则,非常方便的获取到想要的值
提取器在数组的应用
实例代码
def match_arr(arr:Any) = arr match{
//判断arr是数组,并且只有一个元素,该值为0的规则
case Array(0) => println("array:" + 0)
//判断arr是数组,并且只有2个元素的规则,提取出,x和y
case Array(x,y) => println("array: x=" + x +",y=" +y)
//判断arr是数组,并且多余一个元素,且第一个元素为0的规则
case Array(0,_*) => println("array:0-------------")
case _ => println("other") //判断arr是数组
}
运行代码
def main(args: Array[String]) {
match_arr(Array(0))
match_arr(Array(0,1))
match_arr((Array(0,1,2,3)))
match_arr(Array())
}
运行实例的结果:
array:0
array: x=0,y=1
array:0————-
other
case Array(x,y) => println(“array: x=” + x +”,y=” +y) 是一种典型的应用。
提取器在正则表达式中的应用
val pattern = "(\\d+) (\\w+)".r //定义正则
"1234 abc" match {
case pattern(number, chars) => println( number +" " + chars)
}
pattern(number, chars) ,就是将”1234 abc” 通过正则匹配后,变为2个分组,第一个分组为number,第二分组为chars,结果变为 1234 abc
其实extractor 不光是在数组、正则表达式中使用, 比较常见的还有 元组(tuple)
参考资料:
百度网盘:http://pan.baidu.com/share/home?uk=4013289088#category/type=0
微信号:18610086859
DT大数据微信公众账号:DT_Spark
DT大数据梦工厂交流群:462923555/418110145/437123764