13scala模式匹配

Posted haisongvip

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了13scala模式匹配相关的知识,希望对你有一定的参考价值。

1、模式匹配的基础语法

2、对类型进行模式匹配

3、对Array和List的元素进行模式匹配

4、case class与模式匹配

5、Option与模式匹配

1、模式匹配的基础语法

  Scala提供了match case语法,即模式匹配。替代java的switch case。

  两者不同,java中switch case仅能匹配变量的值,比如1、2、3等;scala中的match case可以匹配各种类型,比如变量的类型、集合的元素、有值或无值。

  Match case语法:变量 match{ case 值=>语法}。如果值为下划线,代表了不满足以上所有情况下的默认情况如何处理。此外,match case中,主要一个case分支满足并处理了,就不会继续判断下一个case分支了。Java需要用break阻止。

  案例成绩评价:

  技术分享图片

  模式匹配中使用if守卫:在case后面的条件中,可以在值后面加一个if守卫,进行双重过滤。

  技术分享图片

  在模式匹配中进行赋值:Scala中,可以将模式匹配的默认情况,下划线替换为一个变量名,此时模式匹配会将要匹配的值赋值给这个变量,从而可以在后面的处理语句中使用要匹配的值。(目的是拿到最后一个case _ 的值)

  技术分享图片

2、对类型进行模式匹配

  scala中,模式匹配可以直接匹配类型,而不是值,java的swich case绝对做不到。

  技术分享图片

3、对Array和List的元素进行模式匹配

  对Array进行模式匹配,分别可以匹配带有指定元素的数组、带有指定个数的数组、以某元素打头的数组,对LIst进行模式匹配,与Array类似,但需要使用List特有的::操作符。对朋友打招呼实例:

  技术分享图片

  技术分享图片

4、case class与模式匹配

  case class类,中文也称为样例类,类似java的JavaBean的概念。即只定义field,并由scala编译时自动提供getter和setter方法,但是没有method。

  case class的主构造函数接受的参数通常不需要使用var或val修饰,Scala自动会使用val修饰。(如果指定var修饰,还是会按照var来)。

  scala自动为case class定义了伴生对象,并且定义了apply()方法,该方法接受主构造函数相同的参数,并返回case class对象。

  技术分享图片

5、Option与模式匹配

  Scala中有一种特殊的类型,叫做Option。Option有两种值,一种是Some,表示有值,一种是None,表示没有值。

  Option通常会用于模式匹配中,用于判断某个变量是有值还是无值,比null更加简洁明了。

  技术分享图片

以上是关于13scala模式匹配的主要内容,如果未能解决你的问题,请参考以下文章

(模式)匹配Scala中的字符串[重复]

Scala实战高手****第13课Scala模式匹配实战和Spark源码鉴赏

详解 Scala 模式匹配

Scala 匹配模式

Spark记录-Scala模式匹配

scala 常用模式匹配类型