zoukankan      html  css  js  c++  java
  • 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....
    }

  • 相关阅读:
    函数名的应用/列表推导式
    装饰器/内置函数
    函数的基础
    文件的改的操作
    常用str
    python 定时器 timer QTimer
    Python 2.7.16 pyinstaller3.0 生成exe可执行文件
    python 根据excel单元格内容获取该单元格所在的行号
    python 实现仪器LAN口通信(FLUKE 8846)
    VS2019 MSB8041 MSB8042 Error
  • 原文地址:https://www.cnblogs.com/green-frog-2019/p/11354966.html
Copyright © 2011-2022 走看看