Scala--模式匹配和样例类
模式匹配应用场景:switch语句,类型查询,析构,样例类
一、更好的switch
val ch :Char = '+' val sign =
ch match{
case '+' => 1
case '-' => -1
case _ => 0
} println(sign)
case _ 匹配其他情况,case 结尾不需要break跳出
二、守卫
val ch :Char = '9' var digit = 0 val sign =
ch match{
case '+' => 1
case '-' => -1
case _ => 0
case _ if Character.isDigit(ch) => digit = Character.digit(ch,10)
//case _ => 0
} println(sign,digit)
守卫可以是任何Boolean条件; 匹配是顺序下来的,上面的例子是匹配不到守卫的。
三、模式中的变量
case _ 看做是这个特性的一个特殊情况。
四、类型模式
var str =1
def f(s : Any) = s match{
case i : Int => println("int="+i)
case s : String=> println("str="+s)
case m : Map[String,Int]=> println("map="+m) //Map中的类型匹配是无效的
case _ => println("unknown")
}
f(1)
f("Hello")
f(Map((1,2)))
结果:
int=1
str=Hello
map=Map(1 -> 2)
Map中的类型匹配是无效的,结果为
Map(1 -> 2)
匹配发生在运行期,Java虚拟机中的泛型信息是被擦掉的。
五、匹配数组、列表和元组
数组:
def f (str: Any) = str match{
case Array() => "0"
case Array(x,y) => x + " " + y
case Array(0, _*) => "0..."
case _ => "something else"
}
println(f(Array(1,3)))
println(f(Array(0,1,3)))
1 3
0...
列表:
def fl (str: Any) = str match{
case 0::Nil => "0"
case x::y::Nil => x + " " + y
case 0::tail => "0..."
case _ => "something else"
}
println(fl(List(0)))
println(fl(List(1,3)))
println(fl(List(0,1,3)))
0
1 3
0...
元组:
def ft (str: Any) = str match{
case (0,_) => "0"
case (x,y)=> x + " " + y
case (x,0,_) => "0..."
case _ => "something else"
}
println(ft(Tuple2(0,1)))
println(ft(Tuple3(1,0,2)))
println(ft(Tuple4(1,0,2,3)))
0
0...
something else
六、提取器
模式匹配数组,元组,列表,这些背后是提取器机制。对象中有unapply或unapplySeq方法对值进行提取。
unapply方法用于提取固定数量的对象,unapplySeq提取的是一个序列。
七、变量声明中的模式
val (x,y)=(1,2)
Scala--模式匹配和样例类的更多相关文章
- Scala模式匹配和样例类
Scala有一个十分强大的模式匹配机制,可以应用到很多场合:如switch语句.类型检查等.并且Scala还提供了样例类,对模式匹配进行了优化,可以快速进行匹配. 1.字符匹配 def mai ...
- scala模式匹配与样例类
样本类:添加了case的类便是样本类.这种修饰符可以让Scala编译器自动为这个类添加一些语法上的便捷设定.如下: 1.添加与类名一致的工厂方法.也就是说,可以写成Var("x") ...
- Scala基础:模式匹配和样例类
模式匹配 package com.zy.scala import scala.util.Random /** * 模式匹配 */ object CaseDemo { def main(args: Ar ...
- 学好Spark/Kafka必须要掌握的Scala技术点(二)类、单例/伴生对象、继承和trait,模式匹配、样例类(case class)
3. 类.对象.继承和trait 3.1 类 3.1.1 类的定义 Scala中,可以在类中定义类.以在函数中定义函数.可以在类中定义object:可以在函数中定义类,类成员的缺省访问级别是:publ ...
- 大数据学习day16------第三阶段-----scala04--------1. 模式匹配和样例类 2 Akka通信框架
1. 模式匹配和样例类 Scala有一个十分强大的模式匹配机制,可以应用到很多场合:如switch语句.类型检查等.并且Scala还提供了样例类,对模式匹配进行了优化,可以快速进行匹配 1.1 模式匹 ...
- 【Scala篇】--Scala中Trait、模式匹配、样例类、Actor模型
一.前述 Scala Trait(特征) 相当于 Java 的接口,实际上它比接口还功能强大. 模式匹配机制相当于java中的switch-case. 使用了case关键字的类定义就是样例类(case ...
- Scala学习十四——模式匹配和样例类
一.本章要点 match表达式是更好的switch,不会有意外调入下一个分支 如果没有模式能够匹配,会抛出MatchError,可以用case _模式避免 模式可以包含一个随意定义的条件,称做守卫 你 ...
- Scala集合库、模式匹配和样例类
package com.yz8 import org.junit.Test class test { @Test def test: Unit = { val ints = List(1,5,7,6, ...
- Scala-Unit6-final/type关键字、样例类&样例对象
一.关键字 1.final关键字 用final修饰的类:不能被继承 用final修饰的方法:不能被重写 注意:(1)在Scala中变量不需要用final修饰,因为val与var已经限制了变量是否可变 ...
随机推荐
- Boostrap模态框,以及通过jquery绑定td的值,使模态框回显
做页面不管是登录或是修改信息,难免会使用到模态框,在此分享一个比较漂亮的模态框 Boostrap模态框 使用之前首先导入jquery-3.2.1.min.js,和bootstrap.min.js 先添 ...
- python语言学习--1
第一天 item: 当字符串中出现 反斜杠'\' 时,输出时会把它当做转义字符处理,所以结果中不会出现它,若要正常输出则需要在字符串前面加上r, 我想r的意思是religion即“原始”的意思: it ...
- OpenCV 4.0.1 找不到R.styleable解决
OpenCV 4.0.1作为模块导入Android Studio会有找不到R.styleable的问题. 解决方法 1.导入模块前 将 opencv-4.0.1-android-sdk\OpenCV- ...
- Spark SQL整体架构
0.整体架构 注意:Spark SQL是Spark Core之上的一个模块,所有SQL操作最终都通过Catalyst翻译成类似的Spark程序代码被Spark Core调度执行,其过程也有Job.St ...
- python 函数参数为*和**的作用与区别
def function(*args):print(args) 中*的作用:表示此时参数为一个元祖. def function(**args):print(args)中**的作用:表示此时参数为一个字 ...
- WebAPI接口设计:SwaggerUI文档 / 统一响应格式 / 统一异常处理 / 统一权限验证
为什么还要写这类文章?因为我看过网上很多讲解的都不够全面,而本文结合实际工作讲解了swaggerui文档,统一响应格式,异常处理,权限验证等常用模块,并提供一套完善的案例源代码,在实际工作中可直接参考 ...
- SSM 框架 ---项目整合
一.SSM框架理解 Spring(业务层) Spring就像是整个项目中装配bean的大工厂,在配置文件中可以指定使用特定的参数去调用实体类的构造方法来实例化对象. Spring的核心思想是IoC(控 ...
- C#获取日期的星期名称
private string GetWeekName(DayOfWeek week) { string weekName = ""; switch (week) { case Da ...
- 更换jupyter notebook风格主题、修改默认工作路径(Ubuntu系统和Win系统)
默认的风格对代码关键词的颜色提醒很不明显,而且白色背景长久使用非常刺眼,所以考虑更换主题. 在更换途中,发现代码输出行,前几个字符被遮挡显示不出来,找了很久才解决,备忘一些要点. 1:替换主题方法 h ...
- mysql中的升序和降序以及一个字段升序和一个字段降序
mySql中,升序为asc,降序为desc.例如: 升序:select * from 表名 order by 表中的字段 asc(mysql中默认是升序排列,可不写) 降序:select ...