Scala 提供了强大的模式匹配机制,应用也非常广泛。 一个模式匹配包含了一系列备选项,每个都开始于关键字 case。每个备选项都包含了一个模式及一到多个表达式。箭头符号 => 隔开了模式和表达式。...接下来我们来看一个不同数据类型的模式匹配: object Test { def main(args: Array[String]) { println(matchTest("two")..." case _ => "many" } } 执行以上代码,输出结果为: $ scalac Test.scala $ scala Test 2 many one scala.Int...实例中第一个 case 对应整型数值 1,第二个 case 对应字符串值 two,第三个 case 对应类型模式,用于判断传入的值是否为整型,相比使用isInstanceOf来判断类型,使用模式匹配更好...第四个 case 表示默认的全匹配备选项,即没有找到其他匹配时的匹配项,类似 switch 中的 default。
Scala类型推导 之剑 2016.5.1 00:38:12 类型系统 什么是静态类型?为什么它们很有用?...Scala中的类型 Scala强大的类型系统让我们可以使用更具有表现力的表达式。...所有的类型变量在运行期必须是确定的。 对于静态类型的一个比较常见的缺陷就是有太多的类型语法。Scala提供了类型推导来解决这个问题。...Scala编译器自动推导参数的类型。注意我们也没有必要显示指定返回值的类型了。 型变 Scala的类型系统需要把类的继承关系和多态结合起来。类的继承使得类之间存在父子的关系。...Scala正是因为做了类型推导, 让Coders感觉仿佛在写动态语言的代码.
二、spray-json简介 spray-json是一款使用Scala语言编写的开源Json处理框架。...可以在JSON字符串对象、AST(JSON树)对象、Scala类型之间任意转换。 ...在Scala程序中使用spray-json,只需要在build.sbt文件中添加libraryDependencies += "io.spray" %% "spray-json" % "1.3.2",...三、spray-json使用 总体上使用spray-json需要先定义一个转换的协议(Protocol),该协议指定了如何在Scala对象与JOSN对象之间进行转换。...以分行的方式优雅的输出,compactPrint直接在一行压缩输出,convertTo可以直接将json对象转为Scala对应的类型。
Scala 中提供了基于是否匹配某个条件来执行相应动作的模式匹配,这很类似其他语言的switch-case语句。...所有的匹配表达式都以要匹配的 值 开头, 后面跟着 match 关键字、左花括号、和一组可能匹配到的项以及关联的动作,最后以右花括号结尾。...每一组可能匹配到的项以 关键字case 开头、后面跟匹配表达式,该表达式的值如果与目标值匹配, => 右边的表达式就会作为该match 的结果。...我们以一个划分学生期末成绩等级的例子来解释 Scala 模式匹配的用法: package com.byron4j.scala.basic /** * Scala 模式匹配的用法 */ object...score 的值, score 值为90,则A作为方法执行结果结果;score 值为80,则B作为方法执行结果…下划线_通常用于最后以一个匹配表达式中,指得失如果前面的所有值都未能匹配到,则默认该条件的匹配结果作为方法执行结果
模式匹配 Scala 的模式匹配除了可以对值进行匹配之外,还可以对类型进行匹配、对 Array 和 List 的元素情况进行匹配、对 case class 进行匹配、甚至对有值或没值(Option)...case 可以匹配各种情况,比如变量的类型、集合的元素、有值或无值。 ...对类型进行模式匹配 Scala 的模式匹配一个强大之处就在于,可以直接匹配类型,而不是值!这点是 Java 的 switch case 绝对做不到的。 理论知识:对类型如何进行匹配?...其他语法与匹配值其实是一样的,但是匹配类型的话,就是要用 “case 变量: 类型 => 代码” 这种语法,而不是匹配值的 “case 值 => 代码” 这种语法。...} } Option与模式匹配 Scala 有一种特殊的类型,叫做 Option。Option 有两种值,一种是 Some,表示有值,一种是 None,表示没有值。
case _ => 代码N } eg: import scala.util.Random object MatchApp extends App{ val numbers = Array("one...image.png 在模式匹配的case语句中,还可以使用变量。当colorNum=4时,值4会被传递给number变量。...Unknown" } println(colorStr) } } case类 在定义一个类的,如果在class 关键字前面加上case关键字,该类是case类 package cn.bx.scala
最近开始学习 Scala,相较于学习 Haskell 的过程来看,Scala 真是直观得多,友好得多,更容易上手。...如果和我一样有 Java 经验的话但是从来没有接触过 Scala 的话,建议先阅读这篇文章,A Scala Tutorial for Java Programmers,一边比较,一边熟悉,同时配套的还有这个...再挪到 Scala 里面看模式匹配,上面的情况也都能够支持。...当然,除了上面的情形,模式匹配还可以匹配参数的类型。...Node(e, l, r) => inOrder(l) ::: List(e) ::: inOrder(r) case Leaf => List() } Tree 本身可以有两种类型的实现
常量 类型 数组 列表 元组 对象及样例类 四、声明变量中的模式匹配 五、for表达式模式匹配 六、偏函数模式匹配 ---- 本次主要分享Scala中关于模式匹配的内容,Scala中的模式匹配类似于Java...中的switch语法,但是Scala在基于Java的思想上补充了特有的功能。...Scala 中,模式匹配可以匹配所有的字面量,包括字符串,字符,数字,布尔值等等。...,可以定义模糊的元素类型匹配、元素数量匹配或者精确的某个数组元素值匹配 // 匹配数组 for (arr <- List( Array(0), Array(1, 0),...n元组、匹配元素类型、匹配元素值。
——以及对应的业务服务即可,注意这个路由定义并不是一个配置文件,而是spray-routing定义的一套scala的DSL。...如果找到,则spray会根据你在路由定义里的配置,把请求参数转成业务对象(比如用json4s把json请求转换成scala对象,需要用Entity指令来定义),然后调用业务服务。...比较奇怪的是返回类型是Unit,spray会调用RequestContext里包含的responder成员来负责将响应返回给客户端。...据spray-routing文档里说是为了”non-blocking"和"actor friendly",但实际上在spray的后续版本,也就是akka-http里把这个返回类型改成了RouteResult...,spray要去尝试下一个路径,有点像嵌套的模式匹配。
Scala提供了一种类比switch/case更为强大的选择匹配模式,写作 选择语句 match {可选分支} 它被称为模式匹配,模式匹配包含了一系列以case关键字开头的分支,每一个分支包含一个模式或者是多个表达式...(1) 1 scala> matchTest(2) 2 scala> matchTest(4) 3 match表达式会逐个尝试case里的模式直到匹配为止,如果没有匹配上就会抛出异常MatchError...上例所展示的就是常量模式的常量1,2去匹配,还使用了_通配符匹配任何对象(建议放在最后面,因为Scala的模式匹配是按顺序的)。...> matchTest(("a","b","c")) found:abc 匹配类型的模式 除了上述的匹配模式选出值,还可以用来做类型检查和测试。...这里可以根据传进去的值的类型反馈对应的结果。
将业务尽量分布到小的trait中,然后通过object来组合 多用函数或偏函数对逻辑进行抽象 用隐式转换体现关注点分离,既保证了职责的单一性,又保证了API的流畅性 用getOrElse来封装需要两个分支的模式匹配...对于隐式参数或支持类型转换的隐式调用,应尽量让import语句离调用近一些;对于增加方法的隐式转换(相当于C#的扩展方法),则应将import放在文件头,保持调用代码的干净 在一个模块中,尽量将隐式转换定义放到...使用REST CLIENT对REST服务进行测试,而不能盲目地信任Spray提供的ScalatestRouteTest对客户端请求的模拟,因为这种模拟其实省略了对Json对象的序列化与反序列化; 为核心的...Spray默认对Json序列化的支持是使用的是Json4s,为此Spray提供了Json4sSupport trait;如果需要支持更多自定义类型的Json序列化,需要重写隐式值json4sFormats...因为并非Router都使用Json格式,由于trait定义的继承传递性,可能会导致未使用Json格式的Router出现错误; Json4s可以支持Scala的大多数类型,包括Option等,但不能很好地支持
高级类型 1. 视界(“类型类”) 有时候,你并不需要指定一个类型是等/子/超于另一个类,你可以通过转换这个类来伪装这种关联关系。一个视界指定一个类型可以被“看作是”另一个类型。...= 123 scala> val y: Int = "123" y: Int = 123 scala> math.max("123", 111) res1: Int = 123 //视界,就像类型边界...您可以使用类型限制,例如: scala> class Container[A <% Int] { def addIt(x: A) = 123 + x } defined class Container...可是 Scala 的数字类型并不都共享一个超类,所以我们不能使用T Scala 的 math 库对适当的类型 T 定义了一个隐含的 Numeric[T]。...> (new Container("123")).addIt res15: Int = 246 3.结构类型 Scala 支持结构类型 structural types — 类型需求由接口构造表示,而不是由具体的类型表示
Scala开发的框架与工具,涉及到的领域包括: Database Web Frameworks i18n Authentication Testing JSON Manipulation Serialization...HTTP 严格意义上讲,Spray并非单纯的HTTP框架,它还支持REST、JSON、Caching、Routing、IO等功能。Spray的模块及其之间的关系如下图所示: ?...客户端能够处理自己的逻辑,然后再以JSON格式发送请求给REST服务端。这时,我们将模型视为资源(Resource),视图完全在客户端。...这里的R指的是Resource,而服务端与客户端则通过JSON格式的Resource进行通信。...由于使用了Scala,使得语言的函数式特性得到了最棒的利用。事实上,函数式语言的诸多特性包括不变性、无副作用、组合子等,天生与数据处理匹配。
Scala 的模式匹配是类似与正则匹配的的模式匹配,但是不仅仅如此,它还可以匹配对象的内在的构建形式....模式匹配就是反向的构造器,可以通过嵌套器来构造对象,在构造时提供一些参数 例如: val list = List(3,6) list: List[Int] = List(3, 6) scala> list...scala> def foo(s: String) {s match {case ALIPAY => println("ok")}} foo: (s: String)Unit scala> scala...单纯的通配符模式通常在模式匹配的最后一行出现,case _ => 它可以匹配任何对象,用于处理所有其它匹配不成功的情况。...类型模式 "hello" match { case _:String => println("ok")} ok 如果使用了泛型,它会被擦拭掉,如同java的做法,所以上面的 List[String] 里的
import scala.util.parsing.json.JSON._ import scala.io.Source object ScalaJsonParse { def main(args...Unit = { var tt = Map.empty[String, Any] val tree = parseFull(Source.fromFile("/data/result.json
本文链接:https://blog.csdn.net/u014365862/article/details/100163695 在搭建一些工程项目时,往往需要有配置文件,而配置文件很多是基于json格式组织的...这里可直接看代码: import scala.util.parsing.json.JSON._ import scala.io.Source object XMLHelloWorld { def...main(args: Array[String]): Unit = { def regJson(json:Option[Any]) = json match { case Some...} var tt = Map.empty[String, Any] val tree = parseFull(Source.fromFile("config_params.json...(auc, precision_score, recall_score, ks_value)) git:https://github.com/MachineLP/Spark-/tree/master/scala-json
Any(scala中所有类的超类,表示任意类型), 注意看函数体 x = match{ case 1 => "one" } 这个就是scala中模式匹配的语法结构, 首先变量.match(选择器) 后面跟着一个花括号...,匹的是case语句后面接的是scala变量,如case x if(x == "1") => x等,在使用时一般会加守卫条件(if(...)在模式匹配中就是一个守卫,类型是一个boolean),当然也可以像...元组模式用于匹配scala中的元组内容,用于匹配元组类型的变量内容。...与通配符(_)不同的是,Scala把变量绑定在匹配的对象上。...元组模式:匹配元祖 类型模式:匹配变量的类型 Option 类型 Option类型在Scala程序中经常使用,可以将其与Java中可用的null值进行比较,表示null值。
本篇作为scala快速入门系列的第二十九篇博客,为大家带来的是关于模式匹配的内容。 ?...---- 模式匹配 scala中有一个非常强大的模式匹配机制,可以应用在很多场景: switch语句 类型查询 使用模式匹配快速获取数据 简单模式匹配 在Java中,有switch...---- 匹配类型 除了像Java中的switch匹配数据之外,match表达式还可以进行类型匹配。如果我们要根据不同的数据类型,来执行不同的逻辑,也可以使用match表达式来实现。...示例 定义一个变量为Any类型,然后分别给其赋值为"hadoop"、1、1.0 定义模式匹配,然后分别打印类型的名称 参考代码 ?...---- 本期的内容分享就到这里了,喜欢的小伙伴们记得点个赞,持续关注哟~下期为大家介绍的是scala中的Option类型,敬请期待٩(๑>◡<๑)۶
类型参数 Scala 的类型参数其实意思与 Java 的泛型是一样的,也是定义一种类型参数,比如在集合,在类,在函数中,定义类型参数,然后就可以保证使用到该类型参数的地方,就肯定,也只能是这种类型。...Scala 自动推断泛型类型特性:直接给使用了泛型类型的 field 赋值时, Scala 会自动进行类型推断。...与泛型类一样,你可以通过给使用了泛型类型的变量传递值来让 Scala 自动推断泛型的实际类型,也可以在调用函数时,手动指定泛型类型。...Scala的上下边界特性允许泛型类型必须是某个类的子类,或者必须是某个类的父类。...) for(i <- 0 until food.length) foodPackage(i) = food(i) foodPackage } Existential Type 在 Scala
scala数据类型体系图如下 ?...从上图可以得到以下结论: 在 scala 中有一个根类型 Any ,他是所有类的父类. scala中一切皆为对象,分为两大类AnyVal(值类型),AnyRef(引用类型),他们都是Any子类....Nothing类型也是bottomclass,他是所有类的子类,在开发中通常可以将Nothing类型的值返回 给任意变量或者函数, 这里抛出异常使用很多. scala数据类型介绍 Scala 与 Java...有着相同的数据类型,在Scala中数据类型都是对象,也就是说scala没有java中的原生类型 Scala数据类型分为两大类 AnyVal(值类型) 和 AnyRef(引用类型), 注意:不管是AnyVal...相对于java的类型系统,scala要复杂些!也正是这复杂多变的类型系统才让面向对象编程和函数式编程完美的融合在了一起 scala数据类型列表 数据类型 描述 Byte 8位有符号补码整数。
领取专属 10元无门槛券
手把手带您无忧上云