scala模式匹配使用示例

package com.sparktest

/**
  * case class匹配
  */
class DataFrameWork

//case class 基本就是Java bean,在构造中传参即可
case class ComputationFramework(name: String, popular: Boolean) extends DataFrameWork

case class StorageFramework(name: String, popular: Boolean) extends DataFrameWork


object helloPatternMatch {
  def main(args: Array[String]): Unit = {

    getSalary("Hello", 6)

    getMatchType(100)

    getMatchCollection(Array("Scala"))

    getBigDataType(ComputationFramework("Spark", true))
    
    getValue("Spark",Map("Spark"->"The hottest","Hadoop"->"The olddest"))
  }

  def getSalary(name: String, age: Int): Unit = {
    name match {
      case "Spark" => println("$150000/year")
      case "Hadoop" => println("$100000/year")
      case _ if name == "Scala" => println("$140000/year") //if 守卫
      case _ if name == "Hadoop MapRudece" => println("$90000/year")
      case _name if age >= 5 => println("name:" + _name + "age:" + age + "$120000/year") //变量接受传递的值
      case _ => println("$80000/year")
    }
  }

  /**
    *
    * 对类型进行匹配
    */
  def getMatchType(message: Any): Unit = {
    message match {
      case i: Int => println("Int")
      case s: String => println("String")
      case d: Double => println("Double")
      case array: Array[Int] => println("Array")
      case _ => println("Unkown type")
    }
  }

  /**
    * 对集合进行匹配
    */
  def getMatchCollection(message: Array[String]): Unit = {
    message match {
      case Array("Scala") => println("One Element")
      case Array("Scala", "Java") => println("Two Elements")
      case Array("Spark", _*) => println("More Elements bigins with Spark")
      case _ => println("Unknow Elements")
    }
  }

  /**
    * case class匹配
    */
  def getBigDataType(data: DataFrameWork): Unit = {
    data match {
      case ComputationFramework(name, popular) =>
        println("ComputationFramework" + "name: " + name + " : " + " : popular :" + popular)
      case StorageFramework(name, popular) =>
        println("StorageFramework" + "name: " + name + " : " + " : popular :" + popular)
      case _ => println("Some other type")
    }
  }

  /**
    * Option匹配
    */
  def getValue(key: String, content: Map[String, String]): Unit = {
    content.get(key) match {
      case Some(value) => println(value)
      case None => println("Not Found")
    }
  }

}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值