王家林亲授《DT大数据梦工厂》大数据实战视频 Scala 深入浅出实战经典(1-87讲)完整视频、PPT、代码下载:
百度云盘:http://pan.baidu.com/s/1c0noOt6
腾讯微云:http://url.cn/TnGbdC
360云盘:http://yunpan.cn/cQ4c2UALDjSKy 访问密码 45e2
土豆:http://www.tudou.com/programs/view/dHz5JKJxurM/
优酷:http://v.youku.com/v_show/id_XMTI4OTcwNzY2MA==.html?from=s1.8-1-1.2
爱奇艺:http://www.iqiyi.com/w_19rru5bi79.html#vfrm=2-3-0-1
腾讯视频:http://v.qq.com/boke/page/k/0/d/k016008s0rd.html
技术爱好者尤其是大数据爱好者 可以加DT大数据梦工厂的qq群
DT大数据梦工厂① :462923555
DT大数据梦工厂②:437123764
DT大数据梦工厂③ :418110145
微信公众账号: DT_Spark
王家林老师微信号: 18610086859
王家林老师QQ: 1740415547
王家林老师邮箱: 18610086859@126.com
本视频由王家林老师, 亲自讲解, 完全通过代码实战把您带人大数据的时代.
package com.dt.scala.pattern_match
/**
* @author iken
* @date 2015-08-29
*/
object PatternMatchMore {
def main( args : Array[String] ){
/*
* 1. 对一个未知类型的变量匹配到相应的类型上去
* 这是如此的高级,模式匹配可以在程序运行的时候,智能判断出被匹配的内容的类型
* 注意:Map没有指定其类型,原因是scala在进行模式匹配时,对于接口和泛型,scala会擦出具体的类型
* 所以使用了占位符
*/
def match_type( t : Any ) = t match{
case p: Int => println("It is a integer!")
case p: String => println("It is a Integer!")
case m: Map[_,_] => m.foreach(println)
case _ => println("unknow type!")
}
match_type(2)
match_type(Map("Scala" -> "Spark"))
/*
* 2.对一个未知的数组进行匹配,它可以将数组匹配到具体形式的case上
* case1中是说这个数组只有一个元素,而且该元素必须是0
* case2中是说这个数组具有两个任意元素
* case3中是说这个数据具有任意多元素,且第一个元素必须是0
*/
def match_array( arr : Any ) = arr match{
case Array(0) => println("Array"+"0")
case Array(x,y) => println("Array "+x+" "+y)
case Array(0,_*) => println("Array"+"0 ...")
case _ => println("some thing!")
}
match_array(Array(0))
match_array(Array(0,1))
match_array(Array(0,1,2,3,4))
match_array(Array("hello","world"))
/*
* 3.对一个未知的List进行匹配,它可以将数组匹配到具体形式的case上
* case1中是说这个List只有一个元素,而且该元素必须是0
* case2中是说这个List具有两个任意元素
* case3中是说这个List具有任意多元素,且第一个元素必须是0
*/
def match_list( lst : Any ) = lst match{
case 0 :: Nil => println("List"+"0")
case x :: y :: Nil => println("List "+x+" "+y)
case 0 :: tail => println("List"+"0 ...")
case _ => println("some thing!")
}
match_list(List(0))
match_list(List(0,1))
match_list(List(0,1,2,3,4))
match_list(List("hello","world"))
/*
* 4.对一个未知的Tuple进行匹配,它可以将数组匹配到具体形式的case上
* case1中是说这个Tuple只有一个元素,而且该元素必须是0
* case2中是说这个Tuple具有两个任意元素
* case3中是说这个Tuple具有任意多元素,且第一个元素必须是0
*/
def match_tuple( tuple : Any ) = tuple match{
case (0,_) => println("List"+"0")
case (x,_) => println("List "+x)
case _ => println("some thing!")
}
match_tuple((0,"scala"))
match_tuple(("hello",1))
match_tuple((0,1,2,3,4))
}
}
亿速云「云服务器」,即开即用、新一代英特尔至强铂金CPU、三副本存储NVMe SSD云盘,价格低至29元/月。点击查看>>
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。