Scala模式匹配

模式匹配
  Java:switch case 值 对一个值进行条件判断,返回针对不同的条件进行不同的处理
  Scala:match case 值/类型/集合

基本语法:
变量 match {
  case value1 => 代码1
  case value2 => 代码2
  .....
  case _ => 代码N
}


object MatchApp extends App {

  val names = Array("Akiho Yoshizawa", "YuiHatano", "Aoi Sola")
  val name = names(Random.nextInt(names.length))   //随机取一个名字

  name match {
    case "Akiho Yoshizawa" => println("吉老师...")
    case "YuiHatano" => println("波老师...")
    case _ => println("真不知道你们在说什么...")
  }

  def judgeGrade(grade:String): Unit = {
    grade match {
      case "A" => println("Excellent...")
      case "B" => println("Good...")
      case "C" => println("Just so so...")
      case _ => println("You need work harder...")
    }
  }

  judgeGrade("A")
  judgeGrade("C")
  judgeGrade("D")
}


加条件进行匹配:

object MatchApp extends App {
  def judgeGrade(name:String, grade:String): Unit = {
    grade match {
      case "A" => println("Excellent...")
      case "B" => println("Good...")
      case "C" => println("Just so so...")
      case _ if(name == "lisi") => println(name + " , You are a good boy, but...")    //这里右多了一层判断
      case _ => println("You need work harder...")
    }
  }

  judgeGrade("zhangsan", "D")
  judgeGrade("lisi", "D") //双重过滤
}


Array模式匹配:
object MatchApp extends App {
  def greeting(array:Array[String]): Unit = {
    array match {
      case Array("zhangsan") => println("Hi:zhangsan")
      case Array(x,y) => println("Hi: " + x + " , " + y)
      case Array("zhangsan", _*) => println("Hi:zhangsan and other friends...")    //zhangsan开头的任意个的一个数组。
      case _ => println("Hi: everybody...")
    }
  }

  greeting(Array("zhangsan"))    //走第一个case
  greeting(Array("lisi", "wangwu"))    //走第二个case
  greeting(Array("zhangsan","lisi", "wangwu"))   //走第三个case
  greeting(Array("lisi", "zhangsan", "wangwu"))    //走第四个case
}


List模式匹配:
object MatchApp extends App {
  def greeting(list:List[String]): Unit = {
    list match {
      case "zhangsan" :: Nil => println("Hi:zhangsan")
      case x::y::Nil => println("Hi:" + x + " , " + y)
      case "zhangsan" :: tail => println("Hi: zhangsan and other friends...")
      case _ => println("Hi:everybody...")
    }
  }

  greeting(List("zhangsan"))   //走的第一个case
  greeting(List("lisi", "zhangsan"))   //走的第二个case
  greeting(List("zhangsan","lisi"))    //走的第二个case,先匹配上这个了。因为顺序的问题,所以没有做第三个case,而是走了第二个case。
  greeting(List("PK","zhangsan","lisi"))    //走的第四个case
}


类型匹配:Scala能根据类型做匹配

object MatchApp extends App {
  def matchType(obj:Any): Unit = {
    obj match {
      case x:Int => println("Int")
      case s:String => println("String")
      case m:Map[_,_] => m.foreach(println)
      case _ => println("other type")
    }
  }

  matchType(1)    //Int, 走的第一个case
  matchType("1")    //String,走的第二个case
  matchType(1f)    //other type ,走的第四个case
  matchType(Map("name" -> "PK"))    //(name,PK), 走的第三个case
}

Scala异常处理:
object ExceptionApp extends App {

  //IO
  val file = "test.txt"

  try{

    // open file
    // use file

    val i = 10/0    //是会报错的,不能被0除,需要用try catch。
    println(i)
  } catch {
    case e:ArithmeticException => println("除数不能为0..")
    case e:Exception => println(e.getMessage)
  } finally {
    //释放资源,一定能执行: close file
  }
}

这就是我们常用的一个处理步骤,把要处理的东西丢到try里面,然后在catch里面通过 case 这种方式把我们的异常给捕获到,该怎么处理就是业务逻辑层面的问题了。最后把释放资源写到finally就行了。


case class模式匹配: case class不用new的,直接就能使用。

object CaseClassApp extends App {
  def caseclassMatch(person:Person): Unit = {
    person match {
      case CTO(name,floor) => println("CTO name is: " + name + " , floor is : " + floor)
      case Employee(name,floor) => println("Employee name is: " + name + " , floor is : " + floor)
      case _ => println("other")
    }
  }
  class Person
  case class CTO(name:String, floor:String) extends Person
  case class Employee(name:String, floor:String) extend Person
  case class Other(name:String) extend Person

  caseclassMatch(CTO("PK", "22"))
  caseclassMatch(Employee("zhangsan", "2"))
  caseclassMatch(Other("other"))
}


Some、None 模式匹配:

object CaseClassApp extends App {

  val grades = Map("PK"->"A", "zhangsan"->"C")

  def getGrade(name:String): Unit = {
    val grade = grades.get(name)

    grade match {
      case Some(grade) => println(name + ": your grade is :" + grade)
      case None => println("sorry....")
    }
  }
  getGrade("zhangsan")   //zhangsan: your grade is : C
  getGrade("PK")    //PK: your grade is : A
  getGrade("lisi")    //sorry....
}

 

posted @ 2019-08-14 21:57  我是一只忙碌的小青蛙  阅读(281)  评论(0编辑  收藏  举报