Scala高级语法总结(二)匹配模式match case

本文主要探讨Scala的高级语法——匹配模式match case,包括字符串、数据类型、元组、List和Array、样例类和样例对象以及Option的匹配用法。通过案例演示,展示match case如何提升代码可读性和简化编程。
摘要由CSDN通过智能技术生成

Scala高级语法总结(二)匹配模式match case

1. 背景

  1. scala作为一门对比java更高级的语言,彻底地贯彻面向对象(函数、代码块都是对象,不再有基本类型,静态和非静态代码分别管理等等),支持函数式编程(函数作为一等公民,可以作为参数或者返回值)
  2. scala将java中地switch case功能进一步放大,不过叫做match case。可以匹配地类型更多。
  3. 同样地,scala地match case也需要处理default 情况,而且是必须显式指定。因为match case中传入地类型允许不是同一个类型,所以需要明确指出default类型情况下如何处理。
  4. scala引入地option类型,对比swift语言中地optional类型是一样地,都是2个值,一个是some(value),一个是none。
  5. scala中大量使用匹配模式来简化代码,提升代码可读性。
_  match {
   
case _ 2 => TODO
case _1 => TODO
case _ => 
}
package com.doit.high_level_scala

object MatchTest {
   
  def main(args: Array[String]): Unit = {
   
    test1(3)
  }

  def test1(arg:Any)= arg match {
   
    case x:Int => println("这是一个Int类型")
    case x:Short => println("这是一个Short类型")
    case x:Double => println("这是一个Double类型")
    case x:Long => println("这是一个Long类型")
    case x:String => println("这是一个String类型")
    case x:Float => println("这是一个Float类型")
    case _ => println("其他类型")
  }
}

2. 案例演示

2.1 字符串

可以匹配字符串地值,注意这是大小写敏感的,如有需要,可以先将参数同一为大写或者小写再进行对比。

  def main(args: Array[String]): Unit = {
   
    
    val array: Array[String] = Array("spark", "clickhouse", "storm", "hive", "flink", "hadoop")

    test2(array)
  }

  def test2(arr: Array[String]) = {
   
    val index: Int 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值