美文网首页Scala Tour
[译]Scala Extractor Objects

[译]Scala Extractor Objects

作者: steanxy | 来源:发表于2017-07-11 22:29 被阅读19次

Extractor Object是有unapply方法的对象。apply方法像是构造函数,可以带参数以及创建对象,unapply方法根据对象尝试返回其参数。常用于模式匹配和partial functions。

import scala.util.Random
object CustomerID {
  def apply(name: String) = s"$name--${Random.nextLong}"
  def unapply(customerID: String): Option[String] = {
    val name = customerID.split("--").head
    if (name.nonEmpty) Some(name) else None
  }
}
val customer1ID = CustomerID("Sukyoung")  // Sukyoung--23098234908
customer1ID match {
  case CustomerID(name) => println(name)  // prints Sukyoung
  case _ => println("Could not extract a CustomerID")
}

apply方法根据name创建了CustomerID字符串。unapply逆向获取name参数。当调用CustomerID("Sukyoung")时,相当于调用CustomerID.apply("Sukyoung")。当调用case CustomerID(name) => customer1ID时,相当于调用unapply方法。

unapply方法也可用于赋值。

val customer2ID = CustomerID("Nico")
val CustomerID(name) = customer2ID
println(name)  // prints Nico

等价于val name = CustomerID.unapply(customer2ID).get。如果没有匹配,会抛出scala.MatchError

val CustomerID(name2) = "--asdfasdfasdf"

unapply的返回类型应该按照如下方式选择:

  • 如果只是测试,返回Boolean。例如case even()。
  • 如果返回类型T的一个sub-value,则返回Option[T]。
  • 如果想要返回多个sub-value T1,...,Tn,使用元组组织Option[(T1,...,Tn)]。

有时,sub-value的数量是固定的并且想要返回一个序列。为此,也可以通过unapplySeq定义模式,返回Option[Seq[T]]。这个机制用于匹配模式case List(x1, ..., xn)

相关文章

  • [译]Scala Extractor Objects

    Extractor Object是有unapply方法的对象。apply方法像是构造函数,可以带参数以及创建对象,...

  • 【译】Animate Objects, not Views

    原文地址:https://android.jlelse.eu/animate-objects-not-views-...

  • Handle json response data

    Json response Regular Expression Extractor vs Json Extractor

  • iOS Images Extractor

    iOS Images Extractor iOS Images Extractor is a Mac app to...

  • [译]Scala基础

    在浏览器中尝试Scala 你可以使用ScalaFiddle在浏览器中运行Scala。 访问https://scal...

  • [译]Scala介绍

    Scala是一种现代多范式编程语言,旨在以简介,优雅和类型安全的方式来表达公共编程模式。它集成了面向对象和函数式编...

  • [译]Scala类

    Scala中的类用于创建对象。类中可以包含方法,值,变量,类型,对象,特征以及类,统称为成员。类型,对象和特征稍后...

  • [译]Scala特征

    特征用于在类之间共享接口和字段。类似于Java 8的接口。类和对象可以扩展特征,但是特征不能实例化,因此也没有参数...

  • [译]Scala Currying

    方法可以定义多个参数列表。当调用方法时传递的参数列表少了,则将会产生一个函数,缺失的参数列表会作为这个函数的参数。...

  • PySpark 会比Scala或Java慢吗

    title: PySpark 会比Scala或Java慢吗(译)? date: 2019-07-04 12:07:...

网友评论

    本文标题:[译]Scala Extractor Objects

    本文链接:https://www.haomeiwen.com/subject/sngmhxtx.html