模式匹配java
1 // Scala是没有Java中的switch case语法的,相对应的,Scala提供了更增强大的match case语法,即模式匹配,类替代switch case,match case也被称为模式匹配 2 // Scala的match case与Java的switch case最大的不一样点在于,Java的switch case仅能匹配变量的值,比一、二、3等;而Scala的match case能够匹配各类状况,好比变量的类型、集合的元素、有值或无值 3 // match case的语法以下:变量 match { case 值 => 代码 }。若是值为下划线,则表明了不知足以上全部状况下的默认状况如何处理。此外,match case中,只要一个case分支知足并处理了,就不会继续判断下一个case分支了。(与Java不一样,java的switch case须要用break阻止) 4 // match case语法最基本的应用,就是对变量的值进行模式匹配 5 6 // 案例:成绩评价 7 def judgeGrade(grade: String) { 8 grade match { 9 case "A" => println("Excellent") 10 case "B" => println("Good") 11 case "C" => println("Just so so") 12 case _ => println("you need work harder") 13 } 14 }
在模式匹配中使用if守卫数组
1 // Scala的模式匹配语法,有一个特色在于,能够在case后的条件判断中,不单单只是提供一个值,而是能够在值后面再加一个if守卫,进行双重过滤 2 3 // 案例:成绩评价(升级版) 4 def judgeGrade(name: String, grade: String) { 5 grade match { 6 case "A" => println(name + ", you are excellent") 7 case "B" => println(name + ", you are good") 8 case "C" => println(name + ", you are just so so") 9 case _ if name == "leo" => println(name + ", you are a good boy, come on") 10 case _ => println("you need to work harder") 11 } 12 }
在模式匹配中进行变量赋值app
1 // Scala的模式匹配语法,有一个特色在于,能够将模式匹配的默认状况,下划线,替换为一个变量名,此时模式匹配语法就会将要匹配的值赋值给这个变量,从而能够在后面的处理语句中使用要匹配的值 2 // 为何有这种语法??思考一下。由于只要使用用case匹配到的值,是否是咱们就知道这个只啦!!在这个case的处理语句中,是否是就直接可使用写程序时就已知的值! 3 // 可是对于下划线_这种状况,全部不知足前面的case的值,都会进入_这种默认状况进行处理,此时若是咱们在处理语句中须要拿到具体的值进行处理呢?那就须要使用这种在模式匹配中进行变量赋值的语法!! 4 5 // 案例:成绩评价(升级版) 6 def judgeGrade(name: String, grade: String) { 7 grade match { 8 case "A" => println(name + ", you are excellent") 9 case "B" => println(name + ", you are good") 10 case "C" => println(name + ", you are just so so") 11 case _grade if name == "leo" => println(name + ", you are a good boy, come on, your grade is " + _grade) 12 case _grade => println("you need to work harder, your grade is " + _grade) 13 } 14 }
对类型进行模式匹配函数
1 // Scala的模式匹配一个强大之处就在于,能够直接匹配类型,而不是值!!!这点是java的switch case绝对作不到的。 2 // 理论知识:对类型如何进行匹配?其余语法与匹配值实际上是同样的,可是匹配类型的话,就是要用“case 变量: 类型 => 代码”这种语法,而不是匹配值的“case 值 => 代码”这种语法。 3 4 // 案例:异常处理 5 import java.io._ 6 7 def processException(e: Exception) { 8 e match { 9 case e1: IllegalArgumentException => println("you have illegal arguments! exception is: " + e1) 10 case e2: FileNotFoundException => println("cannot find the file you need read or write!, exception is: " + e2) 11 case e3: IOException => println("you got an error while you were doing IO operation! exception is: " + e3) 12 case _: Exception => println("cannot know which exception you have!" ) 13 } 14 }
对Array和List进行模式匹配spa
1 // 对Array进行模式匹配,分别能够匹配带有指定元素的数组、带有指定个数元素的数组、以某元素打头的数组 2 // 对List进行模式匹配,与Array相似,可是须要使用List特有的::操做符 3 4 // 案例:对朋友打招呼 5 def greeting(arr: Array[String]) { 6 arr match { 7 case Array("Leo") => println("Hi, Leo!") 8 case Array(girl1, girl2, girl3) => println("Hi, girls, nice to meet you. " + girl1 + " and " + girl2 + " and " + girl3) 9 case Array("Leo", _*) => println("Hi, Leo, please introduce your friends to me.") 10 case _ => println("hey, who are you?") 11 } 12 } 13 14 def greeting(list: List[String]) { 15 list match { 16 case "Leo" :: Nil => println("Hi, Leo!") 17 case girl1 :: girl2 :: girl3 :: Nil => println("Hi, girls, nice to meet you. " + girl1 + " and " + girl2 + " and " + girl3) 18 case "Leo" :: tail => println("Hi, Leo, please introduce your friends to me.") 19 case _ => println("hey, who are you?") 20 } 21 }
case class与模式匹配ssr
1 // Scala中提供了一种特殊的类,用case class进行声明,中文也能够称做样例类。case class其实有点相似于Java中的JavaBean的概念。即只定义field,而且由Scala编译时自动提供getter和setter方法,可是没有method。 2 // case class的主构造函数接收的参数一般不须要使用var或val修饰,Scala自动就会使用val修饰(可是若是你本身使用var修饰,那么仍是会按照var来) 3 // Scala自动为case class定义了伴生对象,也就是object,而且定义了apply()方法,该方法接收主构造函数中相同的参数,并返回case class对象 4 5 // 案例:学校门禁 6 class Person 7 case class Teacher(name: String, subject: String) extends Person 8 case class Student(name: String, classroom: String) extends Person 9 10 def judgeIdentify(p: Person) { 11 p match { 12 case Teacher(name, subject) => println("Teacher, name is " + name + ", subject is " + subject) 13 case Student(name, classroom) => println("Student, name is " + name + ", classroom is " + classroom) 14 case _ => println("Illegal access, please go out of the school!") 15 } 16 }
Option与模式匹配excel
// Scala有一种特殊的类型,叫作Option。Option有两种值,一种是Some,表示有值,一种是None,表示没有值。 // Option一般会用于模式匹配中,用于判断某个变量是有值仍是没有值,这比null来的更加简洁明了 // Option的用法必须掌握,由于Spark源码中大量地使用了Option,好比Some(a)、None这种语法,所以必须看得懂Option模式匹配,才可以读懂spark源码。 // 案例:成绩查询 val grades = Map("Leo" -> "A", "Jack" -> "B", "Jen" -> "C") def getGrade(name: String) { val grade = grades.get(name) grade match { case Some(grade) => println("your grade is " + grade) case None => println("Sorry, your grade information is not in the system") } }